:root {
	--hh-forest: #1f4e2e;
	--hh-moss: #496f35;
	--hh-leaf: #87a85b;
	--hh-sage: #dbe7c9;
	--hh-clay: #b4753f;
	--hh-sun: #f2c14e;
	--hh-ink: #16231b;
	--hh-muted: #5f6b62;
	--hh-line: #d8ded7;
	--hh-paper: #fffdf8;
	--hh-soft: #f5f8ef;
	--hh-white: #ffffff;
	--hh-shadow: 0 14px 34px rgba(22, 35, 27, 0.12);
	--hh-radius: 8px;
	--hh-max: 1120px;
	--hh-sans: "DM Sans", "Helvetica Neue", Arial, sans-serif;
	--hh-serif: "Cormorant Garamond", "Georgia", "Times New Roman", serif;
	--hh-script: "Dancing Script", "Segoe Script", "Snell Roundhand", cursive;
}

body.happy-herb-redesign {
	background: var(--hh-paper);
	color: var(--hh-ink);
	font-family: var(--hh-sans);
	letter-spacing: 0;
}

body.happy-herb-redesign #outer-wrap,
body.happy-herb-redesign #wrap,
body.happy-herb-redesign #main {
	background: var(--hh-paper);
}

body.happy-herb-redesign a {
	color: var(--hh-forest);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.16em;
}

body.happy-herb-redesign a:hover {
	color: var(--hh-clay);
}

body.happy-herb-redesign img {
	border-radius: 0;
}

body.happy-herb-redesign .elementor-section.elementor-section-boxed > .elementor-container,
body.happy-herb-redesign .e-con.e-con-boxed > .e-con-inner {
	max-width: var(--hh-max);
}

body.happy-herb-redesign .elementor-widget-heading .elementor-heading-title {
	color: var(--hh-forest);
	letter-spacing: 0;
}

body.happy-herb-redesign .elementor-widget-text-editor {
	color: var(--hh-muted);
	font-size: 16px;
	line-height: 1.75;
}

body.happy-herb-redesign .elementor-widget-button .elementor-button {
	align-items: center;
	background: var(--hh-forest);
	border: 1px solid var(--hh-forest);
	border-radius: var(--hh-radius);
	box-shadow: 0 10px 22px rgba(31, 78, 46, 0.18);
	color: var(--hh-white);
	display: inline-flex;
	font-weight: 600;
	letter-spacing: 0;
	min-height: 46px;
	padding: 12px 20px;
	transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

body.happy-herb-redesign .elementor-widget-button .elementor-button:hover {
	background: var(--hh-clay);
	border-color: var(--hh-clay);
	color: var(--hh-white);
	transform: translateY(-1px);
}

body.happy-herb-redesign .elementor-widget-divider .elementor-divider-separator {
	border-color: rgba(31, 78, 46, 0.16);
}

/* Header */
body.happy-herb-redesign #top-bar-wrap {
	display: none !important;
}

body.happy-herb-redesign #site-header {
	background: rgba(255, 253, 248, 0.96);
	border-bottom: 1px solid rgba(31, 78, 46, 0.14);
	box-shadow: 0 8px 24px rgba(22, 35, 27, 0.07);
	position: sticky;
	top: 0;
	z-index: 1000;
}

body.admin-bar.happy-herb-redesign #site-header {
	top: 32px;
}

/*
 * Inner pages: the Elementor header template (ID 328) contains a large
 * page-title band. With the whole #site-header sticky, that band floated
 * over the content while scrolling. Keep the sticky header on the front
 * page only; inner pages use a static header until the title band is
 * moved into per-page hero sections (Phase 1 rebuild).
 */
body.happy-herb-redesign:not(.home) #site-header {
	position: static;
}

body.happy-herb-redesign .elementor-location-header > .elementor,
body.happy-herb-redesign .elementor-location-header .elementor-element-6c5ffe2,
body.happy-herb-redesign .elementor-location-header .elementor-element-64f7ee8 {
	background: transparent !important;
}

body.happy-herb-redesign .elementor-location-header .elementor-widget-image img {
	height: 58px;
	max-height: none;
	object-fit: contain;
	width: 58px;
}

body.happy-herb-redesign .elementor-location-header .elementor-widget-image a {
	align-items: center;
	column-gap: 12px;
	display: grid;
	grid-template-columns: 58px minmax(130px, auto);
	grid-template-rows: auto auto;
	min-width: 216px;
	text-decoration: none !important;
}

body.happy-herb-redesign .elementor-location-header .elementor-widget-image a::after {
	color: var(--hh-forest);
	content: "Happy Herb";
	font-family: var(--hh-serif);
	font-size: 23px;
	font-weight: 700;
	grid-column: 2;
	grid-row: 1;
	justify-self: start;
	letter-spacing: 0;
	line-height: 0.95;
	text-decoration: none;
	text-align: left;
	white-space: nowrap;
}

body.happy-herb-redesign .elementor-location-header .elementor-widget-image a::before {
	color: var(--hh-muted);
	content: "Cooking Class | Chiang Mai";
	font-size: 9px;
	font-weight: 700;
	grid-column: 2;
	grid-row: 2;
	justify-self: start;
	letter-spacing: 0.13em;
	line-height: 1.3;
	text-decoration: none;
	text-align: left;
	text-transform: uppercase;
	white-space: nowrap;
}

body.happy-herb-redesign .elementor-location-header .elementor-widget-image a > img {
	grid-column: 1;
	grid-row: 1 / 3;
}

@media (min-width: 960px) {
	body.happy-herb-redesign .elementor-location-header .elementor-element-6c5ffe2 > .e-con-inner {
		align-items: center;
		display: flex;
		gap: clamp(18px, 2vw, 34px);
		max-width: 1320px;
		width: 100%;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-3ddb3ab {
		flex: 0 0 auto;
		width: auto;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-e5a8f76 {
		flex: 1 1 auto;
		min-width: 0;
		width: auto;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-f6c8ae5 {
		display: none !important;
	}
}

@media (min-width: 960px) and (max-width: 1180px) {
	body.happy-herb-redesign .elementor-location-header .elementor-widget-image a {
		grid-template-columns: 58px;
		min-width: 58px;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-widget-image a::before,
	body.happy-herb-redesign .elementor-location-header .elementor-widget-image a::after {
		display: none;
	}
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .elementor-nav-menu {
	align-items: center;
	flex-wrap: nowrap;
	gap: 2px;
	justify-content: flex-end;
	width: 100%;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .elementor-item {
	border-radius: 6px;
	color: var(--hh-ink);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.035em;
	line-height: 1.2;
	padding: 11px 8px;
	text-transform: uppercase;
	white-space: nowrap;
}

body.happy-herb-redesign .elementor-location-header .hh-ref-nav-book-now > .elementor-item {
	align-items: center;
	font-weight: 700 !important;
	background: var(--hh-gold);
	border: 1px solid rgba(255, 253, 248, 0.28);
	border-radius: 7px;
	box-shadow: 0 12px 24px rgba(19, 35, 18, 0.18);
	color: var(--hh-white) !important;
	display: inline-flex;
	font-size: 13px;
	justify-content: center;
	letter-spacing: 0.05em;
	line-height: 1;
	margin-left: 8px;
	min-width: 112px;
	padding: 13px 18px;
	text-align: center;
}

body.happy-herb-redesign .elementor-location-header .hh-ref-nav-whatsapp svg {
	display: block;
	height: 24px;
	width: 24px;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item {
	align-items: center;
	background: rgba(37, 211, 102, 0.08);
	border: 2px solid currentColor;
	border-radius: 999px;
	color: #1fa855 !important;
	display: inline-flex;
	height: 44px;
	justify-content: center;
	margin-left: 8px;
	min-width: 44px;
	padding: 0;
	text-shadow: none;
	width: 44px;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item:hover,
body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item.elementor-item-active {
	background: #25d366;
	border-color: #25d366;
	color: var(--hh-white) !important;
	transform: translateY(-1px);
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp__label {
	clip: rect(0, 0, 0, 0);
	height: 1px;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}

body.happy-herb-redesign.page-id-11 .page-header,
body.happy-herb-redesign.home .page-header,
body.happy-herb-redesign.hh-ref-farm-updates-page .page-header {
	display: none !important;
}

body.happy-herb-redesign.hh-ref-farm-updates-page .elementor-widget-theme-page-title {
	display: none !important;
}

@media (min-width: 960px) {
	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-element-6c5ffe2 > .e-con-inner {
		gap: clamp(8px, 1.2vw, 18px);
		max-width: 1240px;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-widget-image img {
		height: 46px;
		width: 46px;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-widget-image a {
		column-gap: 8px;
		grid-template-columns: 46px minmax(96px, auto);
		min-width: 168px;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-widget-image a::after {
		font-size: 18px;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-widget-image a::before {
		font-size: 7px;
		letter-spacing: 0.1em;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-nav-menu--main .elementor-nav-menu {
		gap: 0;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-nav-menu--main .elementor-item {
		font-size: 10.5px;
		letter-spacing: 0.02em;
		padding: 9px 5px;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .hh-ref-nav-book-now > .elementor-item {
		font-size: 11px;
		margin-left: 4px;
		min-width: 86px;
		padding: 11px 10px;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item {
		height: 36px;
		margin-left: 5px;
		min-width: 36px;
		width: 36px;
	}

	body.happy-herb-redesign:not(.home):not(.page-id-11) .elementor-location-header .hh-ref-nav-whatsapp svg {
		height: 19px;
		width: 19px;
	}
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .elementor-item:hover,
body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .elementor-item.elementor-item-active {
	background: rgba(135, 168, 91, 0.16);
	color: var(--hh-forest);
}

body.happy-herb-redesign .elementor-location-header .hh-ref-nav-book-now > .elementor-item:hover,
body.happy-herb-redesign .elementor-location-header .hh-ref-nav-book-now > .elementor-item.elementor-item-active {
	background: #d2a14b;
	border-color: #d2a14b;
	color: var(--hh-white) !important;
	transform: translateY(-1px);
}

body.happy-herb-redesign .elementor-location-header .elementor-widget-search-form input[type="search"] {
	background: var(--hh-white);
	border: 1px solid var(--hh-line);
	border-radius: 999px;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
	min-height: 42px;
	padding-inline: 16px;
}

body.happy-herb-redesign .elementor-location-header .elementor-menu-toggle {
	background: var(--hh-forest);
	border-radius: var(--hh-radius);
	color: var(--hh-white);
	height: 42px;
	min-width: 42px;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown {
	background: rgba(19, 35, 18, 0.98);
	border: 1px solid rgba(255, 253, 248, 0.14);
	box-shadow: 0 18px 34px rgba(13, 28, 12, 0.24);
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown .elementor-item {
	color: var(--hh-white);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.035em;
	padding: 14px 20px;
	text-transform: uppercase;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown .elementor-item:hover,
body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown .elementor-item.elementor-item-active {
	background: rgba(255, 255, 255, 0.08);
	color: #f8e7b8;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown .hh-ref-nav-book-now > .elementor-item {
	background: var(--hh-gold);
	border-radius: 7px;
	color: var(--hh-white) !important;
	margin: 10px 14px 14px;
	text-align: center;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown .hh-ref-nav-whatsapp > .elementor-item {
	align-items: center;
	color: #1fa855;
	display: flex;
	gap: 10px;
}

body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown .hh-ref-nav-whatsapp svg {
	height: 20px;
	width: 20px;
}

/* Homepage */
body.happy-herb-redesign.home .elementor-element-5c13d1f,
body.happy-herb-redesign.page-id-11 .elementor-element-5c13d1f {
	background: var(--hh-ink);
	min-height: clamp(520px, 82vh, 780px);
	overflow: hidden;
	position: relative;
}

body.happy-herb-redesign.page-id-11 .elementor-element-5c13d1f::after {
	background: linear-gradient(180deg, rgba(22, 35, 27, 0.24), rgba(22, 35, 27, 0.72));
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 2;
}

body.happy-herb-redesign.page-id-11 .elementor-element-84f5ccc,
body.happy-herb-redesign.page-id-11 .elementor-element-84f5ccc .elementor-wrapper,
body.happy-herb-redesign.page-id-11 .elementor-element-84f5ccc video,
body.happy-herb-redesign.home .elementor-element-84f5ccc,
body.happy-herb-redesign.home .elementor-element-84f5ccc .elementor-wrapper,
body.happy-herb-redesign.home .elementor-element-84f5ccc video,
body.happy-herb-redesign .elementor-element-84f5ccc audio,
body.happy-herb-redesign .elementor-element-84f5ccc iframe {
	display: none !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-230e1b10,
body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4,
body.happy-herb-redesign.page-id-11 .elementor-element-585d983c {
	background-color: var(--hh-soft) !important;
	background-blend-mode: soft-light;
}

body.happy-herb-redesign.page-id-11 .elementor-element-230e1b10 {
	border-bottom: 1px solid var(--hh-line);
	padding-block: clamp(56px, 8vw, 96px) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-dd264d1 .elementor-heading-title {
	color: var(--hh-forest);
	font-size: clamp(34px, 5vw, 58px);
	font-weight: 800;
	line-height: 1.05;
	max-width: 900px;
}

body.happy-herb-redesign.page-id-11 .elementor-element-585fc1fc {
	max-width: 760px;
}

body.happy-herb-redesign.page-id-11 .elementor-element-585fc1fc,
body.happy-herb-redesign.page-id-11 .elementor-element-585fc1fc p {
	color: #435248;
	font-size: clamp(17px, 2vw, 20px);
	line-height: 1.8;
}

body.happy-herb-redesign.page-id-11 .elementor-element-1de2a7ef {
	background-color: var(--hh-paper) !important;
	border-bottom: 1px solid var(--hh-line);
	padding-block: clamp(60px, 8vw, 104px) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-1de2a7ef .elementor-widget-image img {
	box-shadow: var(--hh-shadow);
	outline: 8px solid var(--hh-white);
}

body.happy-herb-redesign.page-id-11 .elementor-element-d546abc .elementor-heading-title {
	font-size: clamp(30px, 4vw, 46px);
	font-weight: 800;
	line-height: 1.12;
}

body.happy-herb-redesign.page-id-11 .elementor-element-291bab3 .elementor-icon-list-item {
	background: var(--hh-white);
	border: 1px solid var(--hh-line);
	border-radius: var(--hh-radius);
	box-shadow: 0 7px 18px rgba(22, 35, 27, 0.07);
	margin-bottom: 10px;
	padding: 12px 14px;
}

body.happy-herb-redesign.page-id-11 .elementor-element-291bab3 .elementor-icon-list-icon {
	color: var(--hh-clay);
}

body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4 {
	padding-block: clamp(64px, 8vw, 100px) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-f6077de .elementor-heading-title,
body.happy-herb-redesign.page-id-11 .elementor-element-3c6ce61 .elementor-heading-title {
	font-size: clamp(32px, 5vw, 52px);
	font-weight: 800;
	text-align: center;
}

body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4 .elementor-widget-image img {
	aspect-ratio: 4 / 3;
	box-shadow: 0 10px 26px rgba(22, 35, 27, 0.12);
	object-fit: cover;
	width: 100%;
}

body.happy-herb-redesign.page-id-11 .elementor-element-585d983c {
	padding-block: clamp(64px, 8vw, 96px) !important;
}

body.happy-herb-redesign .elementor-widget-gallery img,
body.happy-herb-redesign .elementor-widget-image-gallery img {
	aspect-ratio: 4 / 3;
	box-shadow: 0 8px 18px rgba(22, 35, 27, 0.1);
	object-fit: cover;
	transition: transform 180ms ease, box-shadow 180ms ease;
}

body.happy-herb-redesign .elementor-widget-gallery a:hover img,
body.happy-herb-redesign .elementor-widget-image-gallery a:hover img {
	box-shadow: var(--hh-shadow);
	transform: translateY(-2px);
}

/* Inner pages */
body.happy-herb-redesign:not(.page-id-11) .elementor-widget-theme-page-title .elementor-heading-title {
	color: var(--hh-forest);
	font-size: clamp(34px, 5vw, 56px);
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
}

body.happy-herb-redesign:not(.page-id-11) .elementor-element-1d37c84 {
	background: linear-gradient(180deg, var(--hh-soft), var(--hh-paper));
	border-bottom: 1px solid var(--hh-line);
	padding-block: clamp(34px, 6vw, 72px) !important;
}

/* Booking */
body.happy-herb-redesign.page-id-325 .elementor-element-c5e2e1e {
	background: var(--hh-white);
	border: 1px solid var(--hh-line);
	border-radius: var(--hh-radius);
	box-shadow: var(--hh-shadow);
	padding: clamp(18px, 3vw, 30px);
}

body.happy-herb-redesign.page-id-325 .elementor-form {
	margin: 0;
}

body.happy-herb-redesign.page-id-325 .elementor-field-group {
	margin-bottom: 16px;
}

body.happy-herb-redesign.page-id-325 .elementor-field-label {
	color: var(--hh-ink);
	font-size: 13px;
	font-weight: 700;
	margin-bottom: 6px;
}

body.happy-herb-redesign.page-id-325 .elementor-field,
body.happy-herb-redesign.page-id-325 .elementor-select-wrapper select {
	background: #fffefa;
	border: 1px solid var(--hh-line);
	border-radius: var(--hh-radius);
	color: var(--hh-ink);
	min-height: 46px;
}

body.happy-herb-redesign.page-id-325 .elementor-field:focus,
body.happy-herb-redesign.page-id-325 .elementor-select-wrapper select:focus {
	border-color: var(--hh-forest);
	box-shadow: 0 0 0 3px rgba(31, 78, 46, 0.13);
	outline: none;
}

body.happy-herb-redesign.page-id-325 .elementor-element-3abd2cb {
	background: rgba(242, 193, 78, 0.18);
	border: 1px solid rgba(180, 117, 63, 0.28);
	border-radius: var(--hh-radius);
	color: #6b431f;
	margin-top: 18px;
	padding: 14px 16px;
}

body.happy-herb-redesign.page-id-325 .elementor-element-69ae8c18 .elementor-heading-title {
	font-size: clamp(28px, 4vw, 42px);
	font-weight: 800;
}

body.happy-herb-redesign.page-id-325 .elementor-element-3a4feb97 .elementor-widget-image img {
	aspect-ratio: 4 / 3;
	box-shadow: 0 8px 20px rgba(22, 35, 27, 0.1);
	object-fit: cover;
	width: 100%;
}

body.happy-herb-redesign.page-id-325 .elementor-element-3a4feb97 .elementor-widget-button .elementor-button {
	background: var(--hh-clay);
	border-color: var(--hh-clay);
	box-shadow: 0 10px 22px rgba(180, 117, 63, 0.2);
	width: 100%;
}

body.happy-herb-redesign.page-id-325 .elementor-element-3a4feb97 .elementor-widget-button .elementor-button:hover {
	background: var(--hh-forest);
	border-color: var(--hh-forest);
}

/* Contact */
body.happy-herb-redesign.page-id-22 .elementor-widget-theme-page-title,
body.happy-herb-redesign.page-id-22 .page-header,
body.happy-herb-redesign.page-id-22 .elementor-location-footer {
	display: none !important;
}

body.happy-herb-redesign.page-id-22 .site-main {
	background: var(--hh-paper);
}

.hh-ref-contact-hero {
	background: linear-gradient(180deg, rgba(245, 248, 239, 0.92), rgba(255, 253, 248, 1));
	padding: clamp(44px, 7vw, 82px) 24px clamp(34px, 5vw, 58px);
}

.hh-ref-contact-hero__inner {
	align-items: stretch;
	display: grid;
	gap: clamp(24px, 4vw, 46px);
	grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
	margin-inline: auto;
	max-width: 1180px;
}

.hh-ref-contact-hero__copy > span,
.hh-ref-contact-card > span,
.hh-ref-contact-cta span {
	color: var(--hh-clay);
	display: block;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.hh-ref-contact-hero h1 {
	color: var(--hh-forest);
	font-family: var(--hh-serif);
	font-size: clamp(42px, 6vw, 72px);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 0.95;
	margin: 0 0 18px;
	max-width: 780px;
}

.hh-ref-contact-hero p,
.hh-ref-contact-card p,
.hh-ref-contact-card li,
.hh-ref-contact-cta p {
	color: var(--hh-muted);
	font-size: 16px;
	line-height: 1.7;
	margin: 0;
}

.hh-ref-contact-hero__copy > p {
	max-width: 650px;
}

.hh-ref-contact-hero__actions,
.hh-ref-contact-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 28px;
}

.hh-ref-contact-hero__actions a,
.hh-ref-contact-card__link,
.hh-ref-contact-cta__actions a {
	align-items: center;
	border-radius: 8px;
	display: inline-flex;
	font-size: 13px;
	font-weight: 800;
	justify-content: center;
	letter-spacing: 0;
	min-height: 46px;
	padding: 12px 18px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ref-contact-hero__actions a:first-child,
.hh-ref-contact-card__link,
.hh-ref-contact-cta__actions a:first-child {
	background: var(--hh-forest);
	border: 1px solid var(--hh-forest);
	color: var(--hh-white) !important;
}

.hh-ref-contact-hero__actions a:last-child,
.hh-ref-contact-cta__actions a:last-child {
	background: transparent;
	border: 1px solid rgba(31, 78, 46, 0.22);
	color: var(--hh-forest) !important;
}

.hh-ref-contact-hero__panel {
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 8px;
	box-shadow: 0 18px 34px rgba(22, 35, 27, 0.1);
	display: grid;
	gap: 14px;
	padding: clamp(22px, 3vw, 30px);
}

.hh-ref-contact-hero__panel h2,
.hh-ref-contact-card h2,
.hh-ref-contact-cta h2 {
	color: var(--hh-forest);
	font-family: var(--hh-serif);
	font-size: clamp(28px, 3.5vw, 42px);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
	margin: 0;
}

.hh-ref-contact-hero__panel a,
.hh-ref-contact-hero__panel p {
	background: var(--hh-soft);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	color: var(--hh-muted) !important;
	display: block;
	font-size: 15px;
	line-height: 1.55;
	padding: 14px 16px;
	text-decoration: none !important;
}

.hh-ref-contact-hero__panel a span,
.hh-ref-contact-hero__panel p span {
	color: var(--hh-deep-2);
	display: block;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.05em;
	margin-bottom: 3px;
	text-transform: uppercase;
}

.hh-ref-contact-hero__panel a small {
	color: rgba(95, 107, 98, 0.76);
	display: block;
	font-size: 13px;
	margin-top: 2px;
}

.hh-ref-contact-main {
	display: grid;
	gap: 22px;
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
	margin-inline: auto;
	max-width: 1180px;
	padding: clamp(42px, 7vw, 78px) 24px;
}

.hh-ref-contact-card {
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 8px;
	box-shadow: 0 14px 28px rgba(22, 35, 27, 0.08);
	display: grid;
	gap: 14px;
	padding: clamp(22px, 3vw, 30px);
}

.hh-ref-contact-card--location {
	grid-row: span 2;
}

.hh-ref-contact-map-links {
	display: grid;
	gap: 10px;
	margin-top: 8px;
}

.hh-ref-contact-map-links a {
	background: var(--hh-soft);
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 8px;
	color: var(--hh-forest) !important;
	display: grid;
	gap: 3px;
	padding: 14px 16px;
	text-decoration: none !important;
}

.hh-ref-contact-map-links strong {
	font-size: 13px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.hh-ref-contact-map-links small {
	color: var(--hh-muted);
	font-size: 13px;
}

.hh-ref-contact-card ul {
	display: grid;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.hh-ref-contact-card li {
	padding-left: 20px;
	position: relative;
}

.hh-ref-contact-card li::before {
	color: var(--hh-gold);
	content: "✓";
	font-weight: 800;
	left: 0;
	position: absolute;
	top: 0;
}

.hh-ref-contact-cta {
	align-items: center;
	background: var(--hh-forest);
	color: var(--hh-white);
	display: grid;
	gap: 22px;
	grid-template-columns: minmax(0, 1fr) auto;
	margin: 0 auto clamp(42px, 7vw, 78px);
	max-width: 1180px;
	padding: clamp(28px, 5vw, 44px) 24px;
}

.hh-ref-contact-cta span,
.hh-ref-contact-cta h2 {
	color: var(--hh-white);
}

.hh-ref-contact-cta p {
	color: rgba(255, 253, 248, 0.82);
	max-width: 660px;
}

.hh-ref-contact-cta__actions {
	justify-content: flex-end;
	margin-top: 0;
}

.hh-ref-contact-cta__actions a:first-child {
	background: var(--hh-sun);
	border-color: var(--hh-sun);
	color: var(--hh-ink) !important;
}

.hh-ref-contact-cta__actions a:last-child {
	border-color: rgba(255, 253, 248, 0.42);
	color: var(--hh-white) !important;
}

/* Farm Updates & Blog */
.hh-ref-blog-page {
	background: var(--hh-paper);
	color: var(--hh-ink);
	font-family: var(--hh-sans);
	letter-spacing: 0;
}

.hh-ref-blog-hero {
	background: linear-gradient(180deg, rgba(245, 248, 239, 0.94), rgba(255, 253, 248, 1));
	padding: clamp(44px, 7vw, 84px) 24px clamp(30px, 5vw, 58px);
}

.hh-ref-blog-hero__inner {
	align-items: center;
	display: grid;
	gap: clamp(28px, 5vw, 58px);
	grid-template-columns: minmax(0, 0.95fr) minmax(340px, 1.05fr);
	margin-inline: auto;
	max-width: 1180px;
}

.hh-ref-blog-hero__copy > span,
.hh-ref-blog-section__heading > span,
.hh-ref-blog-cta span {
	color: var(--hh-clay);
	display: block;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.hh-ref-blog-hero h1 {
	color: var(--hh-forest);
	font-family: var(--hh-serif);
	font-size: clamp(46px, 7vw, 84px);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 0.92;
	margin: 0 0 20px;
}

.hh-ref-blog-hero p {
	color: var(--hh-muted);
	font-size: clamp(17px, 2vw, 20px);
	line-height: 1.65;
	margin: 0;
	max-width: 620px;
}

.hh-ref-blog-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 28px;
}

.hh-ref-blog-hero__actions a,
.hh-ref-blog-cta a {
	align-items: center;
	border-radius: 8px;
	display: inline-flex;
	font-size: 13px;
	font-weight: 800;
	justify-content: center;
	letter-spacing: 0;
	min-height: 46px;
	padding: 12px 18px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ref-blog-hero__actions a:first-child,
.hh-ref-blog-cta a {
	background: var(--hh-forest);
	border: 1px solid var(--hh-forest);
	color: var(--hh-white) !important;
}

.hh-ref-blog-hero__actions a:last-child {
	background: transparent;
	border: 1px solid rgba(31, 78, 46, 0.22);
	color: var(--hh-forest) !important;
}

.hh-ref-blog-hero__image {
	aspect-ratio: 1.2;
	margin: 0;
	overflow: hidden;
}

.hh-ref-blog-hero__image img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.hh-ref-blog-section {
	margin-inline: auto;
	max-width: 1180px;
	padding: clamp(42px, 7vw, 78px) 24px;
}

.hh-ref-blog-section--soft {
	background: var(--hh-soft);
	max-width: none;
}

.hh-ref-blog-section--soft > * {
	margin-inline: auto;
	max-width: 1180px;
}

.hh-ref-blog-section__heading {
	margin-bottom: clamp(24px, 4vw, 36px);
	max-width: 760px;
}

.hh-ref-blog-section__heading h2,
.hh-ref-blog-cta h2 {
	color: var(--hh-forest);
	font-family: var(--hh-serif);
	font-size: clamp(34px, 5vw, 56px);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 0.98;
	margin: 0 0 14px;
}

.hh-ref-blog-section__heading p,
.hh-ref-blog-cta p {
	color: var(--hh-muted);
	font-size: 16px;
	line-height: 1.7;
	margin: 0;
}

.hh-ref-blog-grid {
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hh-ref-blog-card {
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 8px;
	box-shadow: 0 14px 28px rgba(22, 35, 27, 0.08);
	display: grid;
	overflow: hidden;
}

.hh-ref-blog-card__image {
	aspect-ratio: 1.28;
	display: block;
	overflow: hidden;
	text-decoration: none !important;
}

.hh-ref-blog-card__image img {
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 180ms ease;
	width: 100%;
}

.hh-ref-blog-card:hover .hh-ref-blog-card__image img {
	transform: scale(1.025);
}

.hh-ref-blog-card__body {
	display: grid;
	gap: 12px;
	padding: 20px;
}

.hh-ref-blog-card__meta {
	align-items: center;
	color: rgba(95, 107, 98, 0.82);
	display: flex;
	flex-wrap: wrap;
	font-size: 12px;
	font-weight: 700;
	gap: 8px;
	line-height: 1.35;
}

.hh-ref-blog-card__meta span {
	color: var(--hh-clay);
	text-transform: uppercase;
}

.hh-ref-blog-card h3 {
	font-family: var(--hh-serif);
	font-size: clamp(24px, 2.4vw, 30px);
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0;
}

.hh-ref-blog-card h3 a {
	color: var(--hh-forest) !important;
	text-decoration: none !important;
}

.hh-ref-blog-card p {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.65;
	margin: 0;
}

.hh-ref-blog-card__link {
	color: var(--hh-forest) !important;
	font-size: 13px;
	font-weight: 800;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ref-blog-empty {
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 8px;
	padding: clamp(24px, 4vw, 38px);
}

.hh-ref-blog-empty h3 {
	color: var(--hh-forest);
	font-family: var(--hh-serif);
	font-size: 32px;
	line-height: 1;
	margin: 0 0 10px;
}

.hh-ref-blog-empty p {
	color: var(--hh-muted);
	line-height: 1.7;
	margin: 0;
}

.hh-ref-blog-pagination {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
	margin-top: 34px;
}

.hh-ref-blog-pagination .page-numbers {
	align-items: center;
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.18);
	border-radius: 8px;
	color: var(--hh-forest) !important;
	display: inline-flex;
	font-size: 13px;
	font-weight: 800;
	height: 40px;
	justify-content: center;
	min-width: 40px;
	padding: 0 12px;
	text-decoration: none !important;
}

.hh-ref-blog-pagination .page-numbers.current {
	background: var(--hh-forest);
	color: var(--hh-white) !important;
}

.hh-ref-blog-cta {
	align-items: center;
	background: var(--hh-forest);
	color: var(--hh-white);
	display: grid;
	gap: 22px;
	grid-template-columns: minmax(0, 1fr) auto;
	margin: 0 auto clamp(42px, 7vw, 78px);
	max-width: 1180px;
	padding: clamp(28px, 5vw, 44px) 24px;
}

.hh-ref-blog-cta span,
.hh-ref-blog-cta h2,
.hh-ref-blog-cta p {
	color: var(--hh-white);
}

.hh-ref-blog-cta p {
	color: rgba(255, 253, 248, 0.82);
	max-width: 620px;
}

.hh-ref-blog-cta a {
	background: var(--hh-sun);
	border-color: var(--hh-sun);
	color: var(--hh-ink) !important;
	white-space: nowrap;
}

/* Footer */
body.happy-herb-redesign .elementor-location-footer,
body.happy-herb-redesign #footer,
body.happy-herb-redesign #footer-widgets,
body.happy-herb-redesign #footer-bottom {
	display: none !important;
}

.hh-ref-site-footer {
	background: var(--hh-warm-paper);
	color: var(--hh-ink);
	font-family: var(--hh-sans);
}

.hh-ref-footer-utility {
	background:
		linear-gradient(90deg, rgba(19, 35, 18, 0.98), rgba(32, 53, 29, 0.96)),
		var(--hh-deep-2);
	color: rgba(255, 253, 248, 0.82);
}

.hh-ref-footer-utility__inner {
	display: grid;
	gap: 0;
	grid-template-columns: 1.25fr 1fr 0.82fr 1.25fr;
	margin-inline: auto;
	max-width: 1240px;
	padding: clamp(30px, 4.5vw, 50px) 24px;
}

.hh-ref-footer-utility__group {
	border-right: 1px solid rgba(255, 253, 248, 0.22);
	min-height: 180px;
	padding: 0 clamp(24px, 3vw, 42px);
}

.hh-ref-footer-utility__group:first-child {
	padding-left: 0;
}

.hh-ref-footer-utility__group:last-child {
	border-right: 0;
	padding-right: 0;
}

.hh-ref-footer-utility h2,
.hh-ref-footer-main h2 {
	font-family: var(--hh-serif);
	font-size: 22px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.15;
	margin: 0 0 14px;
}

.hh-ref-footer-utility h2 {
	color: #f2ddb1;
}

.hh-ref-footer-main h2 {
	color: var(--hh-forest);
}

.hh-ref-footer-utility ul {
	display: grid;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.hh-ref-footer-utility li {
	align-items: flex-start;
	display: grid;
	font-size: 13px;
	gap: 9px;
	grid-template-columns: 16px minmax(0, 1fr);
	line-height: 1.45;
}

.hh-ref-footer-utility li::before {
	color: var(--hh-gold);
	content: "\2713";
	font-weight: 700;
	line-height: 1.35;
}

.hh-ref-footer-utility__perfect li {
	align-items: center;
	grid-template-columns: 24px minmax(0, 1fr);
}

.hh-ref-footer-utility__perfect li::before {
	content: none;
}

.hh-ref-footer-utility__icon {
	color: #f2ddb1;
	display: inline-flex;
	height: 19px;
	width: 19px;
}

.hh-ref-footer-utility__icon svg {
	fill: none;
	height: 100%;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.9;
	width: 100%;
}

.hh-ref-footer-utility__languages li {
	align-items: center;
	grid-template-columns: 22px minmax(0, 1fr);
}

.hh-ref-footer-utility__languages li::before {
	content: none;
}

.hh-ref-flag {
	border-radius: 2px;
	box-shadow: 0 0 0 1px rgba(255, 253, 248, 0.35), 0 4px 10px rgba(0, 0, 0, 0.16);
	display: inline-block;
	height: 14px;
	overflow: hidden;
	width: 20px;
}

.hh-ref-flag--gb {
	background:
		linear-gradient(36deg, transparent 43%, #ffffff 43% 48%, #c8102e 48% 53%, #ffffff 53% 58%, transparent 58%),
		linear-gradient(144deg, transparent 43%, #ffffff 43% 48%, #c8102e 48% 53%, #ffffff 53% 58%, transparent 58%),
		linear-gradient(90deg, transparent 38%, #ffffff 38% 45%, #c8102e 45% 55%, #ffffff 55% 62%, transparent 62%),
		linear-gradient(0deg, transparent 34%, #ffffff 34% 43%, #c8102e 43% 57%, #ffffff 57% 66%, transparent 66%),
		#012169;
}

.hh-ref-flag--th {
	background: linear-gradient(
		to bottom,
		#a51931 0 16%,
		#f7f7f7 16% 32%,
		#2d2a4a 32% 68%,
		#f7f7f7 68% 84%,
		#a51931 84% 100%
	);
}

.hh-ref-footer-utility p {
	font-size: 13px;
	line-height: 1.7;
	margin: 0 0 16px;
}

.hh-ref-footer-utility a {
	color: #f2ddb1 !important;
	font-size: 13px;
	font-weight: 700;
	text-decoration: none !important;
}

.hh-ref-footer-pickup {
	align-items: end;
	display: grid;
	gap: 18px;
	grid-template-columns: minmax(0, 1fr) minmax(116px, 148px);
}

.hh-ref-footer-pickup__copy {
	min-width: 0;
}

.hh-ref-footer-pickup__car {
	display: block;
	filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.24));
	max-width: 150px;
	width: 100%;
}

.hh-ref-footer-pickup__car svg {
	display: block;
	height: auto;
	width: 100%;
}

.hh-ref-footer-pickup__car svg path {
	stroke: rgba(17, 30, 18, 0.48);
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 3;
}

.hh-ref-footer-pickup__car svg path:nth-of-type(1) {
	fill: #f4f2ec;
}

.hh-ref-footer-pickup__car svg path:nth-of-type(2) {
	fill: #dbe3df;
}

.hh-ref-footer-pickup__car svg path:nth-of-type(3),
.hh-ref-footer-pickup__car svg path:nth-of-type(4) {
	fill: #202822;
}

.hh-ref-footer-pickup__car svg path:nth-of-type(5),
.hh-ref-footer-pickup__car svg path:nth-of-type(6) {
	fill: #f4f2ec;
}

.hh-ref-footer-main {
	background: var(--hh-warm-paper);
	border-top: 1px solid rgba(31, 78, 46, 0.12);
}

.hh-ref-footer-main__inner {
	display: grid;
	gap: clamp(22px, 3vw, 38px);
	grid-template-columns: minmax(220px, 0.95fr) minmax(132px, 0.58fr) minmax(190px, 0.75fr) minmax(320px, 1.24fr);
	margin-inline: auto;
	max-width: 1320px;
	padding: clamp(34px, 5vw, 58px) 24px;
}

.hh-ref-footer-brand img {
	display: block;
	height: auto;
	margin-bottom: 18px;
	max-width: 94px;
}

.hh-ref-footer-brand p,
.hh-ref-footer-contact p,
.hh-ref-footer-hours p {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.7;
	margin: 0 0 18px;
}

.hh-ref-footer-brand__button {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 8px;
	color: var(--hh-white) !important;
	display: inline-flex;
	font-size: 13px;
	font-weight: 700;
	justify-content: center;
	margin-top: 18px;
	min-height: 42px;
	padding: 10px 20px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ref-footer-brand__contact {
	display: grid;
	gap: 9px;
}

.hh-ref-footer-brand__contact h2 {
	font-size: 22px;
	margin: 0 0 3px;
}

.hh-ref-footer-brand__contact a {
	color: var(--hh-muted) !important;
	display: block;
	font-family: var(--hh-sans);
	font-size: 14px;
	line-height: 1.45;
	overflow-wrap: anywhere;
	text-decoration: none !important;
}

.hh-ref-footer-brand__contact a:hover {
	color: var(--hh-forest) !important;
}

.hh-ref-footer-brand__contact a span {
	color: var(--hh-deep-2);
	display: block;
	font-family: var(--hh-sans);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.35;
	text-transform: none;
}

.hh-ref-footer-brand__contact a small {
	color: rgba(95, 107, 98, 0.74);
	display: block;
	font-family: var(--hh-sans);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.35;
	margin-top: 1px;
}

.hh-ref-footer-links,
.hh-ref-footer-contact,
.hh-ref-footer-hours {
	display: grid;
	align-content: start;
	gap: 8px;
}

.hh-ref-footer-links a,
.hh-ref-footer-contact a,
.hh-ref-footer-bottom a {
	color: var(--hh-muted) !important;
	font-size: 14px;
	line-height: 1.45;
	text-decoration: none !important;
}

.hh-ref-footer-links a:hover,
.hh-ref-footer-contact a:hover,
.hh-ref-footer-bottom a:hover {
	color: var(--hh-forest) !important;
}

.hh-ref-footer-map-links {
	display: grid;
	gap: 8px;
	margin: -4px 0 18px;
}

.hh-ref-footer-contact .hh-ref-footer-map-link {
	align-items: center;
	background: rgba(255, 253, 248, 0.72);
	border: 1px solid rgba(31, 78, 46, 0.16);
	border-radius: 8px;
	color: var(--hh-deep-2) !important;
	display: grid;
	gap: 9px;
	grid-template-columns: 30px minmax(0, 1fr);
	line-height: 1.25;
	padding: 9px 10px;
	text-decoration: none !important;
}

.hh-ref-footer-map-link__icon {
	align-items: center;
	background: rgba(70, 112, 51, 0.1);
	border-radius: 999px;
	color: var(--hh-moss);
	display: inline-flex;
	height: 30px;
	justify-content: center;
	width: 30px;
}

.hh-ref-footer-map-link__icon svg {
	display: block;
	fill: none;
	height: 16px;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.9;
	width: 16px;
}

.hh-ref-footer-map-link__copy {
	align-items: start;
	display: grid;
	gap: 2px;
	min-width: 0;
}

.hh-ref-footer-map-link__copy > span {
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	white-space: nowrap;
}

.hh-ref-footer-map-link__copy small {
	color: var(--hh-muted);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0;
}

.hh-ref-footer-contact .hh-ref-footer-map-link:hover {
	background: var(--hh-moss);
	border-color: var(--hh-moss);
	color: var(--hh-white) !important;
}

.hh-ref-footer-map-link:hover .hh-ref-footer-map-link__icon {
	background: rgba(255, 253, 248, 0.18);
	color: var(--hh-white);
}

.hh-ref-footer-map-link:hover .hh-ref-footer-map-link__copy small {
	color: rgba(255, 253, 248, 0.82);
}

.hh-ref-footer-contact h2:nth-of-type(2),
.hh-ref-footer-hours h2:nth-of-type(2) {
	margin-top: 14px;
}

.hh-ref-footer-hours span {
	color: rgba(95, 107, 98, 0.78);
}

.hh-ref-footer-social {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.hh-ref-footer-social a {
	align-items: center;
	background: var(--hh-deep-2);
	border-radius: 999px;
	color: var(--hh-white) !important;
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	height: 38px;
	justify-content: center;
	text-decoration: none !important;
	width: 38px;
}

.hh-ref-footer-social svg {
	display: block;
	height: 17px;
	width: 17px;
}

.hh-ref-footer-social a:hover {
	background: var(--hh-gold);
	color: var(--hh-white) !important;
}

.hh-ref-footer-bottom {
	align-items: center;
	border-top: 1px solid rgba(31, 78, 46, 0.12);
	display: flex;
	gap: 18px;
	justify-content: space-between;
	margin-inline: auto;
	max-width: 1240px;
	padding: 18px 24px 22px;
}

.hh-ref-footer-bottom p {
	color: rgba(95, 107, 98, 0.84);
	font-size: 13px;
	margin: 0;
}

.hh-ref-footer-bottom div {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

/* Reusable redesign components for upcoming Elementor rebuilds */
.hh-section {
	padding: 72px 24px;
}

.hh-section__inner {
	margin-inline: auto;
	max-width: var(--hh-max);
}

.hh-kicker {
	color: var(--hh-clay);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0;
	margin: 0 0 8px;
	text-transform: uppercase;
}

.hh-title {
	color: var(--hh-forest);
	font-size: 36px;
	font-weight: 800;
	line-height: 1.18;
	margin: 0 0 14px;
}

.hh-copy {
	color: var(--hh-muted);
	font-size: 16px;
	line-height: 1.75;
	margin: 0;
	max-width: 68ch;
}

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

.hh-card {
	background: var(--hh-white);
	border: 1px solid var(--hh-line);
	border-radius: var(--hh-radius);
	box-shadow: 0 8px 22px rgba(22, 35, 27, 0.08);
	padding: 20px;
}

.hh-card__title {
	color: var(--hh-forest);
	font-size: 20px;
	font-weight: 800;
	line-height: 1.25;
	margin: 0 0 8px;
}

.hh-card__meta {
	color: var(--hh-clay);
	font-size: 14px;
	font-weight: 700;
	margin: 0 0 12px;
}

.hh-booking-panel {
	background: var(--hh-white);
	border: 1px solid var(--hh-line);
	border-radius: var(--hh-radius);
	box-shadow: var(--hh-shadow);
	display: grid;
	gap: 24px;
	grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
	padding: 24px;
}

.hh-booking-summary {
	background: #f6f9ef;
	border: 1px solid rgba(111, 143, 61, 0.24);
	border-radius: var(--hh-radius);
	padding: 18px;
}

.hh-notice {
	background: rgba(242, 193, 78, 0.18);
	border: 1px solid rgba(180, 117, 63, 0.28);
	border-radius: var(--hh-radius);
	color: #6b431f;
	padding: 12px 14px;
}

@media (max-width: 959px) {
	.hh-ref-contact-hero__inner,
	.hh-ref-contact-main,
	.hh-ref-contact-cta {
		grid-template-columns: 1fr;
	}

	.hh-ref-contact-card--location {
		grid-row: auto;
	}

	.hh-ref-contact-cta {
		align-items: start;
	}

	.hh-ref-contact-cta__actions {
		justify-content: start;
	}

	.hh-ref-blog-hero__inner {
		grid-template-columns: 1fr;
	}

	.hh-ref-blog-hero__image {
		aspect-ratio: 1.45;
	}

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

	.hh-ref-blog-cta {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.hh-ref-blog-cta a {
		justify-self: start;
	}

	body.admin-bar.happy-herb-redesign #site-header {
		top: 46px;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-widget-image img {
		max-height: 62px;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown {
		background: var(--hh-paper);
		border: 1px solid var(--hh-line);
		box-shadow: var(--hh-shadow);
	}

	body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--dropdown .elementor-item {
		color: var(--hh-ink);
		font-size: 15px;
		font-weight: 700;
	}

	.hh-card-grid,
	.hh-booking-panel {
		grid-template-columns: 1fr;
	}

	.hh-section {
		padding: 56px 20px;
	}

	.hh-title {
		font-size: 30px;
	}
}

@media (max-width: 767px) {
	.hh-ref-contact-hero,
	.hh-ref-contact-main {
		padding-inline: 18px;
	}

	.hh-ref-contact-hero h1 {
		font-size: clamp(40px, 14vw, 58px);
	}

	.hh-ref-contact-hero__actions a,
	.hh-ref-contact-card__link,
	.hh-ref-contact-cta__actions,
	.hh-ref-contact-cta__actions a {
		width: 100%;
	}

	.hh-ref-contact-cta {
		margin-inline: 18px;
		padding-inline: 18px;
	}

	.hh-ref-blog-hero {
		padding-inline: 18px;
	}

	.hh-ref-blog-hero h1 {
		font-size: clamp(42px, 15vw, 58px);
	}

	.hh-ref-blog-hero__actions a,
	.hh-ref-blog-cta a {
		width: 100%;
	}

	.hh-ref-blog-section {
		padding-inline: 18px;
	}

	.hh-ref-blog-grid {
		grid-template-columns: 1fr;
	}

	.hh-ref-blog-card__body {
		padding: 18px;
	}

	.hh-ref-blog-cta {
		margin-inline: 18px;
		padding-inline: 18px;
	}

	body.happy-herb-redesign.page-id-11 .elementor-element-5c13d1f,
	body.happy-herb-redesign.page-id-11 .elementor-element-84f5ccc,
	body.happy-herb-redesign.page-id-11 .elementor-element-84f5ccc .elementor-wrapper,
	body.happy-herb-redesign.page-id-11 .elementor-element-84f5ccc video {
		min-height: 420px;
	}

	body.happy-herb-redesign.page-id-325 .elementor-element-c5e2e1e {
		padding: 18px;
	}

	body.happy-herb-redesign .elementor-location-footer .elementor-icon-list-item {
		align-items: flex-start;
	}

	.hh-section {
		padding: 44px 16px;
	}

	.hh-title {
		font-size: 26px;
	}
}

/* Reference direction: boutique farm cooking experience */
body.happy-herb-redesign {
	--hh-cream: #f6f0e5;
	--hh-warm-paper: #fbf6ec;
	--hh-gold: #c99a45;
	--hh-deep: #132312;
	--hh-deep-2: #20351d;
	--hh-serif: "Cormorant Garamond", "Georgia", "Times New Roman", serif;
	--hh-script: "Dancing Script", "Segoe Script", "Snell Roundhand", cursive;
}

body.happy-herb-redesign.page-id-11 #site-header {
	background: linear-gradient(180deg, rgba(13, 28, 12, 0.78), rgba(13, 28, 12, 0.2));
	border: 0;
	box-shadow: none;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

body.admin-bar.happy-herb-redesign.page-id-11 #site-header {
	top: 32px;
}

@media (min-width: 960px) {
	body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-element-6c5ffe2 > .e-con-inner {
		gap: clamp(24px, 2.6vw, 44px);
	}

	body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-element-3ddb3ab {
		flex: 0 0 292px;
	}

	body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .elementor-nav-menu {
		gap: 0;
		justify-content: flex-end;
	}

	body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .elementor-item {
		font-size: 13px;
		letter-spacing: 0.015em;
		padding: 10px 8px;
	}

	body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .hh-ref-nav-book-now > .elementor-item {
		margin-left: 6px;
		min-width: 104px;
		padding-inline: 14px;
	}
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .elementor-item {
	color: rgba(255, 253, 248, 0.94);
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.26);
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .elementor-item:hover,
body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .elementor-item.elementor-item-active {
	background: rgba(255, 255, 255, 0.1);
	color: #f8e7b8;
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .hh-ref-nav-book-now > .elementor-item,
body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .hh-ref-nav-book-now > .elementor-item:hover,
body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .hh-ref-nav-book-now > .elementor-item.elementor-item-active {
	background: var(--hh-gold);
	border-color: rgba(255, 253, 248, 0.24);
	color: var(--hh-white) !important;
	text-shadow: none;
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 253, 248, 0.92);
	color: var(--hh-white) !important;
	text-shadow: none;
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item:hover,
body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item.elementor-item-active {
	background: #25d366;
	border-color: #25d366;
	color: var(--hh-white) !important;
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-widget-search-form {
	display: none;
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-widget-image img {
	filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.28));
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-widget-image a::after {
	background: url("../images/branding/happy-herb-cooking-class-white-wordmark-chiang-mai.png") left center / contain no-repeat;
	content: "";
	height: 34px;
	margin-top: 1px;
	text-indent: -9999px;
	width: 150px;
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-widget-image a::before {
	color: #f4d28a;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.28);
}

body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header .elementor-widget-button .elementor-button,
body.happy-herb-redesign.hh-ref-header-dark .elementor-location-header a[href*="booking"] {
	background: var(--hh-gold);
	border-color: var(--hh-gold);
	color: var(--hh-white) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-5c13d1f {
	display: none !important;
}

.hh-ref-hero {
	--hh-ref-hero-height: clamp(560px, 72vh, 700px);
	background: var(--hh-deep);
	color: var(--hh-white);
	isolation: isolate;
	min-height: var(--hh-ref-hero-height);
	overflow: hidden;
	position: relative;
}

.hh-ref-hero::before {
	background-image: var(--hh-hero-image);
	background-position: center center;
	background-size: cover;
	content: "";
	inset: 0;
	position: absolute;
	transform: scale(1.01);
	z-index: -2;
}

.hh-ref-hero__shade {
	background:
		linear-gradient(90deg, rgba(11, 25, 10, 0.93) 0%, rgba(11, 25, 10, 0.72) 33%, rgba(11, 25, 10, 0.28) 66%, rgba(11, 25, 10, 0.1) 100%),
		linear-gradient(180deg, rgba(0, 0, 0, 0.38), rgba(0, 0, 0, 0.24) 45%, rgba(0, 0, 0, 0.68));
	inset: 0;
	position: absolute;
	z-index: -1;
}

.hh-ref-hero__inner {
	align-items: center;
	display: flex;
	margin-inline: auto;
	max-width: 1240px;
	min-height: var(--hh-ref-hero-height);
	padding: 104px 42px 48px;
}

.hh-ref-hero__copy {
	max-width: 610px;
}

.hh-ref-hero__title {
	color: var(--hh-white);
	font-family: var(--hh-serif);
	font-size: clamp(42px, 4.8vw, 66px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.03;
	margin: 0;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.36);
	text-wrap: balance;
}

.hh-ref-hero__script {
	color: #f2ddb1;
	font-family: var(--hh-script);
	font-size: clamp(34px, 3.8vw, 50px);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin: 12px 0 18px;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.28);
}

.hh-ref-hero__text {
	color: rgba(255, 255, 255, 0.93);
	font-size: clamp(16px, 1.35vw, 18px);
	line-height: 1.65;
	margin: 0;
	max-width: 560px;
}

.hh-ref-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 28px;
}

.hh-ref-button {
	align-items: center;
	border-radius: 8px;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--hh-sans);
	font-size: 15px;
	font-weight: 600;
	justify-content: center;
	letter-spacing: 0;
	min-height: 54px;
	min-width: 176px;
	padding: 14px 24px;
	text-decoration: none !important;
	transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.hh-ref-button:hover {
	transform: translateY(-1px);
}

.hh-ref-button--primary {
	background: #496f35;
	border: 1px solid #5f8846;
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22);
	color: var(--hh-white) !important;
}

.hh-ref-button--primary:hover {
	background: var(--hh-gold);
	border-color: var(--hh-gold);
}

.hh-ref-button--ghost {
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.38);
	color: var(--hh-white) !important;
}

.hh-ref-button--ghost:hover {
	background: var(--hh-white);
	border-color: var(--hh-white);
	color: var(--hh-deep) !important;
}

.hh-ref-button--video {
	background: transparent !important;
	border: 0;
	color: var(--hh-white) !important;
	gap: 10px;
	min-width: 0;
	padding-inline: 8px 12px;
}

.hh-ref-button--video:hover {
	background: transparent !important;
	color: #f2ddb1 !important;
}

.hh-ref-button__play {
	align-items: center;
	border: 2px solid rgba(255, 255, 255, 0.86);
	border-radius: 999px;
	display: inline-flex;
	height: 48px;
	justify-content: center;
	position: relative;
	width: 46px;
}

.hh-ref-button__play::before {
	border-bottom: 9px solid transparent;
	border-left: 13px solid currentColor;
	border-top: 9px solid transparent;
	content: "";
	margin-left: 3px;
}

.hh-ref-hero__proof {
	align-items: center;
	color: rgba(255, 255, 255, 0.9);
	display: flex;
	flex-wrap: nowrap;
	gap: 0;
	margin-top: 26px;
	max-width: calc(100vw - 84px);
	width: max-content;
}

.hh-ref-hero__proof-item {
	align-items: center;
	border-right: 1px solid rgba(255, 255, 255, 0.25);
	display: flex;
	flex: 0 0 auto;
	gap: 10px;
	min-height: 50px;
	padding: 0 16px;
}

.hh-ref-hero__proof-item:first-child {
	padding-left: 0;
}

.hh-ref-hero__proof-item:last-child {
	border-right: 0;
	padding-right: 0;
}

.hh-ref-hero__proof-icon {
	color: var(--hh-white);
	display: inline-flex;
	flex: 0 0 auto;
	height: 34px;
	opacity: 0.96;
	width: 34px;
}

.hh-ref-hero__proof-icon svg {
	fill: none;
	height: 100%;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.8;
	width: 100%;
}

.hh-ref-hero__proof-copy {
	display: grid;
	gap: 4px;
	line-height: 1.15;
	white-space: nowrap;
}

.hh-ref-hero__proof-copy strong {
	color: var(--hh-white);
	font-size: 14px;
	font-weight: 600;
}

.hh-ref-hero__proof-copy span {
	color: rgba(255, 255, 255, 0.84);
	font-size: 12px;
	font-weight: 500;
}

.hh-ref-benefits {
	background: var(--hh-warm-paper);
	border-bottom: 1px solid rgba(31, 78, 46, 0.12);
	box-shadow: 0 10px 30px rgba(22, 35, 27, 0.05);
}

.hh-ref-benefits__inner {
	display: grid;
	gap: 0;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	margin-inline: auto;
	max-width: 1240px;
	padding: 24px 28px;
}

.hh-ref-benefit {
	align-items: center;
	border-right: 1px solid rgba(31, 78, 46, 0.12);
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 8px 14px;
	text-align: center;
}

.hh-ref-benefit:last-child {
	border-right: 0;
}

.hh-ref-benefit__icon {
	color: var(--hh-moss);
	display: inline-flex;
	height: 34px;
	width: 34px;
}

.hh-ref-benefit__icon svg {
	fill: none;
	height: 100%;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.8;
	width: 100%;
}

.hh-ref-benefit strong {
	color: var(--hh-deep);
	font-size: 14px;
	font-weight: 600;
}

.hh-ref-benefit span:last-child {
	color: var(--hh-muted);
	font-size: 12px;
	line-height: 1.45;
}

.hh-ref-trust {
	background: var(--hh-deep-2);
	color: rgba(255, 253, 248, 0.82);
}

.hh-ref-trust__inner {
	align-items: center;
	display: grid;
	gap: clamp(22px, 2.6vw, 38px);
	grid-template-columns: minmax(140px, 180px) minmax(0, 1fr) minmax(190px, 270px);
	margin-inline: auto;
	max-width: 1480px;
	min-height: 104px;
	padding: 22px 32px;
}

.hh-ref-trust__label {
	color: rgba(255, 253, 248, 0.68);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.16em;
	line-height: 1.45;
	margin: 0;
	text-transform: uppercase;
}

.hh-ref-trust__logos {
	align-items: center;
	display: flex;
	flex-wrap: nowrap;
	gap: clamp(18px, 2vw, 30px);
	justify-content: center;
	min-width: 0;
}

.hh-ref-trust__logos span {
	color: rgba(255, 253, 248, 0.86);
	font-family: var(--hh-serif);
	font-size: clamp(20px, 1.65vw, 26px);
	font-weight: 600;
	line-height: 1;
	white-space: nowrap;
}

.hh-ref-trust__rating {
	align-items: flex-end;
	display: flex;
	flex-direction: column;
	gap: 6px;
	justify-self: end;
	text-align: right;
}

.hh-ref-trust__stars {
	color: var(--hh-gold);
	font-size: 16px;
	letter-spacing: 0.16em;
	line-height: 1;
}

.hh-ref-trust__rating span:last-child {
	color: rgba(255, 253, 248, 0.72);
	font-size: 13px;
	line-height: 1.35;
}

.hh-ref-reviews {
	background:
		linear-gradient(180deg, rgba(255, 253, 248, 0.96), rgba(251, 246, 236, 0.98)),
		var(--hh-warm-paper);
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(42px, 5.5vw, 70px) 24px;
}

.hh-ref-reviews__inner {
	margin-inline: auto;
	max-width: 1380px;
}

.hh-ref-reviews__header {
	margin-bottom: clamp(20px, 2.6vw, 30px);
	text-align: center;
}

.hh-ref-reviews__heading {
	margin-inline: auto;
	max-width: 680px;
}

.hh-ref-reviews__eyebrow {
	color: var(--hh-gold);
	display: block;
	font-family: var(--hh-script);
	font-size: clamp(32px, 3.4vw, 44px);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 8px;
}

.hh-ref-reviews__header h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(32px, 3.35vw, 48px);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1.08;
	margin: 0;
}

.hh-ref-reviews__ornament {
	background: linear-gradient(90deg, transparent, var(--hh-gold), transparent);
	display: block;
	height: 2px;
	margin: 10px auto 0;
	position: relative;
	width: 70px;
}

.hh-ref-reviews__ornament::before,
.hh-ref-reviews__ornament::after {
	background: var(--hh-gold);
	content: "";
	height: 6px;
	position: absolute;
	top: -2px;
	transform: rotate(45deg);
	width: 6px;
}

.hh-ref-reviews__ornament::before {
	left: 25px;
}

.hh-ref-reviews__ornament::after {
	right: 25px;
}

.hh-ref-reviews__score {
	align-items: center;
	background: rgba(255, 253, 248, 0.82);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 999px;
	box-shadow: 0 10px 24px rgba(42, 55, 35, 0.08);
	display: grid;
	gap: 1px 8px;
	grid-template-columns: auto auto;
	margin: 14px auto 0;
	padding: 7px 13px 8px;
	text-align: left;
	width: fit-content;
}

.hh-ref-reviews__score strong {
	color: var(--hh-deep);
	font-size: 22px;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 0.95;
}

.hh-ref-reviews__score strong span {
	color: var(--hh-muted);
	font-size: 12px;
	font-weight: 700;
}

.hh-ref-reviews__stars {
	color: #f4a51c;
	font-size: 12px;
	letter-spacing: 0.08em;
	line-height: 1;
}

.hh-ref-reviews__score small {
	color: var(--hh-muted);
	font-size: 8px;
	font-weight: 700;
	grid-column: 1 / -1;
	letter-spacing: 0;
	line-height: 1.35;
	text-transform: uppercase;
}

.hh-ref-reviews__groups {
	display: grid;
	gap: clamp(22px, 3vw, 36px);
}

.hh-ref-review-row {
	margin: 0;
}

.hh-ref-review-row__header {
	align-items: end;
	display: grid;
	gap: 14px;
	grid-template-columns: minmax(0, 1fr) auto;
	margin-bottom: 12px;
}

.hh-ref-review-row__label {
	color: var(--hh-gold);
	display: block;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 0.1em;
	line-height: 1.3;
	margin-bottom: 3px;
	text-transform: uppercase;
}

.hh-ref-review-row__header h3 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: 25px;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1.12;
	margin: 0;
}

.hh-ref-review-row__source-link {
	align-items: center;
	color: var(--hh-deep-2) !important;
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	gap: 7px;
	justify-content: center;
	letter-spacing: 0;
	line-height: 1.2;
	min-height: 0;
	padding: 0;
	text-decoration: none !important;
	white-space: nowrap;
}

.hh-ref-review-row__source-link > span:last-child {
	border-bottom: 1px solid transparent;
}

.hh-ref-review-row__source-link:hover {
	color: var(--hh-forest) !important;
}

.hh-ref-review-row__source-link:hover > span:last-child {
	border-color: currentColor;
}

.hh-ref-review-row__source-mark {
	align-items: center;
	display: inline-flex;
	flex: 0 0 auto;
	justify-content: center;
	line-height: 1;
}

.hh-ref-review-row__source-logo {
	display: block;
	height: auto;
	width: 17px;
}

.hh-ref-review-row__source-logo--tripadvisor {
	width: 22px;
}

.hh-ref-reviews__cards {
	display: grid;
	gap: clamp(12px, 1.2vw, 16px);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.hh-ref-review-card {
	background: rgba(255, 253, 248, 0.86);
	border: 1px solid rgba(31, 78, 46, 0.1);
	border-radius: 8px;
	box-shadow: 0 12px 28px rgba(42, 55, 35, 0.08);
	display: grid;
	gap: 7px;
	margin: 0;
	min-height: 176px;
	padding: clamp(13px, 1.15vw, 16px);
}

.hh-ref-review-card__meta {
	align-items: center;
	display: grid;
	gap: 9px;
	grid-template-columns: 42px minmax(0, 1fr);
}

.hh-ref-review-card__avatar {
	align-items: center;
	aspect-ratio: 1;
	background:
		linear-gradient(135deg, rgba(31, 78, 46, 0.92), rgba(135, 168, 91, 0.92)),
		var(--hh-moss);
	border: 2px solid rgba(255, 253, 248, 0.92);
	border-radius: 50%;
	box-shadow: 0 10px 20px rgba(31, 78, 46, 0.18);
	color: var(--hh-white);
	display: inline-flex;
	font-size: 12px;
	font-weight: 800;
	height: 42px;
	justify-content: center;
	overflow: hidden;
	width: 42px;
}

.hh-ref-review-card__avatar img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.hh-ref-review-card h4 {
	color: var(--hh-deep);
	font-family: var(--hh-sans);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.18;
	margin: 0 0 2px;
}

.hh-ref-review-card__meta span:last-child {
	color: var(--hh-muted);
	display: block;
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.35;
	text-transform: uppercase;
}

.hh-ref-review-card__stars {
	color: #f4a51c;
	font-size: 12px;
	letter-spacing: 0.08em;
	line-height: 1;
	margin-top: 1px;
}

.hh-ref-review-card p {
	color: var(--hh-ink);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1.5;
	margin: 0;
}

.hh-ref-license {
	background:
		radial-gradient(circle at 16% 12%, rgba(201, 154, 69, 0.1), transparent 28%),
		linear-gradient(180deg, rgba(255, 253, 248, 0.96), rgba(251, 246, 236, 0.98)),
		var(--hh-warm-paper);
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(30px, 4.8vw, 58px) 24px;
}

.hh-ref-license__inner {
	align-items: center;
	background: rgba(255, 253, 248, 0.92);
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 8px;
	box-shadow: 0 20px 48px rgba(42, 55, 35, 0.09);
	display: grid;
	gap: clamp(22px, 3vw, 38px);
	grid-template-columns: minmax(170px, 230px) minmax(350px, 1.08fr) minmax(320px, 0.92fr);
	margin-inline: auto;
	max-width: 1140px;
	padding: clamp(24px, 3vw, 34px);
}

.hh-ref-license__document {
	background: #fffefa;
	border: 1px solid rgba(31, 78, 46, 0.13);
	border-radius: 6px;
	box-shadow: 0 14px 30px rgba(42, 55, 35, 0.13);
	justify-self: center;
	margin: 0;
	max-width: 230px;
	padding: 8px;
	position: relative;
}

.hh-ref-license__document::after {
	border: 1px solid rgba(201, 154, 69, 0.28);
	border-radius: 4px;
	content: "";
	inset: 8px;
	pointer-events: none;
	position: absolute;
}

.hh-ref-license__document-label {
	background: var(--hh-deep-2);
	border-radius: 999px;
	color: var(--hh-white);
	display: inline-flex;
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1;
	padding: 7px 9px;
	position: absolute;
	right: -10px;
	text-transform: uppercase;
	top: 18px;
	z-index: 2;
}

.hh-ref-license__document img {
	border-radius: 4px;
	display: block;
	height: auto;
	width: 100%;
}

.hh-ref-license__document figcaption {
	color: rgba(42, 55, 35, 0.6);
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.35;
	margin: 7px 0 0;
	text-align: center;
	text-transform: uppercase;
}

.hh-ref-license__copy span {
	color: var(--hh-gold);
	display: block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.13em;
	line-height: 1;
	margin-bottom: 8px;
	text-transform: uppercase;
}

.hh-ref-license__copy h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(30px, 3vw, 42px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.02;
	margin: 0 0 10px;
}

.hh-ref-license__copy p {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.65;
	margin: 0;
	max-width: 500px;
}

.hh-ref-license__verification {
	align-items: start;
	display: grid;
	gap: 14px;
}

.hh-ref-license__details {
	display: grid;
	gap: 14px;
	margin: 0;
}

.hh-ref-license__details div {
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	display: grid;
	gap: 4px;
	grid-template-columns: minmax(150px, 0.68fr) minmax(190px, 1fr);
	padding-bottom: 12px;
}

.hh-ref-license__details div:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.hh-ref-license__details dt {
	color: rgba(42, 55, 35, 0.62);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.35;
	margin: 0;
	text-transform: uppercase;
}

.hh-ref-license__details dd {
	color: var(--hh-deep);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.45;
	margin: 0;
}

.hh-ref-license__note {
	color: rgba(42, 55, 35, 0.66);
	font-size: 12px;
	line-height: 1.55;
	margin: 0;
}

.hh-ref-license__link {
	align-items: center;
	background: var(--hh-deep-2);
	border-radius: 8px;
	color: var(--hh-white) !important;
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.04em;
	line-height: 1.25;
	min-height: 46px;
	padding: 12px 18px;
	text-align: center;
	text-decoration: none !important;
	text-transform: uppercase;
	white-space: nowrap;
}

.hh-ref-license__link:hover {
	background: var(--hh-gold);
	color: var(--hh-white) !important;
}

.hh-ref-story {
	background: var(--hh-warm-paper);
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(34px, 5vw, 58px) 24px;
}

.hh-ref-story__inner {
	align-items: center;
	display: grid;
	gap: clamp(26px, 4vw, 44px);
	grid-template-columns: minmax(190px, 250px) minmax(260px, 360px) minmax(420px, 1fr);
	margin-inline: auto;
	max-width: 1240px;
}

.hh-ref-story__eyebrow {
	align-items: center;
	color: var(--hh-gold);
	display: inline-flex;
	font-size: 12px;
	font-weight: 600;
	gap: 10px;
	letter-spacing: 0.12em;
	line-height: 1;
	margin-bottom: 14px;
	text-transform: uppercase;
}

.hh-ref-story__eyebrow::after {
	background: rgba(201, 154, 69, 0.56);
	content: "";
	display: inline-block;
	height: 1px;
	width: 42px;
}

.hh-ref-story__portrait {
	aspect-ratio: 0.72;
	border: 1px solid rgba(201, 154, 69, 0.2);
	border-radius: 46% 46% 44% 44%;
	box-shadow: 0 18px 40px rgba(42, 55, 35, 0.13);
	overflow: hidden;
	position: relative;
}

.hh-ref-story__portrait::after {
	border: 1px solid rgba(201, 154, 69, 0.36);
	border-radius: inherit;
	content: "";
	inset: 10px;
	pointer-events: none;
	position: absolute;
}

.hh-ref-story__portrait img {
	height: 100%;
	object-fit: cover;
	object-position: 50% 34%;
	width: 100%;
}

.hh-ref-story__copy h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(34px, 3.4vw, 48px);
	font-weight: 600;
	line-height: 1.04;
	margin: 0 0 18px;
}

.hh-ref-story__copy p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.75;
	margin: 0 0 24px;
}

.hh-ref-story__button {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 6px;
	color: var(--hh-white) !important;
	display: inline-flex;
	font-size: 13px;
	font-weight: 600;
	justify-content: center;
	min-height: 44px;
	min-width: 144px;
	padding: 12px 20px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ref-story__features {
	background: rgba(255, 253, 248, 0.72);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	overflow: hidden;
}

.hh-ref-story__feature {
	align-items: flex-start;
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	display: grid;
	gap: 16px;
	grid-template-columns: 48px minmax(0, 1fr);
	min-height: 132px;
	padding: 28px;
}

.hh-ref-story__feature:nth-child(odd) {
	border-right: 1px solid rgba(31, 78, 46, 0.1);
}

.hh-ref-story__feature:nth-last-child(-n+2) {
	border-bottom: 0;
}

.hh-ref-story__number {
	color: rgba(201, 154, 69, 0.9);
	display: inline-block;
	font-family: var(--hh-serif);
	font-size: 26px;
	font-weight: 600;
	letter-spacing: 0.02em;
	line-height: 1;
	padding-top: 2px;
}

.hh-ref-story__feature strong {
	color: var(--hh-deep-2);
	display: block;
	font-family: var(--hh-serif);
	font-size: 20px;
	font-weight: 600;
	line-height: 1.15;
	margin-bottom: 8px;
}

.hh-ref-story__feature span:last-child {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.55;
}

.hh-ref-why {
	background: #fffdf8;
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(42px, 6vw, 74px) 24px;
}

.hh-ref-why__inner {
	align-items: stretch;
	display: grid;
	gap: clamp(30px, 5vw, 64px);
	grid-template-columns: minmax(280px, 400px) minmax(520px, 1fr);
	margin-inline: auto;
	max-width: 1240px;
}

.hh-ref-why__copy {
	align-self: center;
}

.hh-ref-why__copy h2,
.hh-ref-section-heading h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-weight: 600;
	letter-spacing: 0;
}

.hh-ref-why__copy h2 {
	font-size: clamp(34px, 3.4vw, 48px);
	line-height: 1.08;
	margin: 0;
}

.hh-ref-ornament {
	align-items: center;
	display: flex;
	gap: 8px;
	margin: 18px 0 22px;
	width: 116px;
}

.hh-ref-ornament::before,
.hh-ref-ornament::after {
	background: rgba(201, 154, 69, 0.72);
	content: "";
	display: block;
	height: 1px;
	width: 48px;
}

.hh-ref-ornament::before {
	width: 24px;
}

.hh-ref-why__copy p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.7;
	margin: 0 0 24px;
}

.hh-ref-why__copy ul {
	display: grid;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.hh-ref-why__copy li {
	align-items: flex-start;
	color: var(--hh-ink);
	display: grid;
	font-size: 15px;
	gap: 10px;
	grid-template-columns: 22px minmax(0, 1fr);
	line-height: 1.45;
}

.hh-ref-why__copy li::before {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 999px;
	color: var(--hh-white);
	content: "\2713";
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	height: 20px;
	justify-content: center;
	margin-top: 1px;
	width: 20px;
}

.hh-ref-why__gallery {
	align-self: stretch;
	display: grid;
	gap: 12px;
	grid-template-columns: minmax(0, 1.44fr) minmax(180px, 0.82fr);
	grid-template-rows: repeat(3, minmax(0, 1fr));
	height: 100%;
	min-height: clamp(330px, 24vw, 390px);
}

.hh-ref-why__image {
	background: var(--hh-paper);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	box-shadow: 0 14px 34px rgba(31, 78, 46, 0.08);
	margin: 0;
	min-height: 0;
	overflow: hidden;
	position: relative;
}

.hh-ref-why__image--main {
	grid-row: span 3;
}

.hh-ref-why__image img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.hh-ref-why__image:not(.hh-ref-why__image--main) {
	aspect-ratio: 2.05;
}

.hh-ref-packages {
	background:
		linear-gradient(180deg, rgba(255, 253, 248, 0.94), rgba(250, 244, 232, 0.98)),
		var(--hh-paper);
	padding: clamp(44px, 6vw, 76px) 24px clamp(52px, 7vw, 84px);
}

.hh-ref-packages__inner {
	margin-inline: auto;
	max-width: 1240px;
}

.hh-ref-section-heading {
	margin: 0 auto 30px;
	max-width: 760px;
	text-align: center;
}

.hh-ref-section-heading span {
	color: var(--hh-gold);
	display: block;
	font-family: var(--hh-script);
	font-size: clamp(32px, 3.4vw, 44px);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 6px;
}

.hh-ref-section-heading h2 {
	font-size: clamp(34px, 3.6vw, 48px);
	line-height: 1.05;
	margin: 0 0 12px;
}

.hh-ref-section-heading p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.65;
	margin: 0 auto;
	max-width: 680px;
}

.hh-ref-package-grid {
	display: grid;
	gap: clamp(22px, 3vw, 34px);
	/* 3x2 layout: six packages, three per row. */
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hh-ref-package-card {
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	box-shadow: 0 16px 38px rgba(42, 55, 35, 0.11);
	display: flex;
	flex-direction: column;
	margin: 0;
	overflow: hidden;
	position: relative;
}

.hh-ref-package-card__media {
	position: relative;
}

.hh-ref-package-card__media img {
	aspect-ratio: 1.76;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.hh-ref-package-card--elephant .hh-ref-package-card__media img {
	object-position: center 58%;
}

.hh-ref-package-card__icon {
	align-items: center;
	background: var(--hh-moss);
	border: 2px solid rgba(255, 253, 248, 0.88);
	border-radius: 999px;
	box-shadow: 0 10px 24px rgba(20, 36, 18, 0.22);
	color: var(--hh-white);
	display: inline-flex;
	height: 58px;
	justify-content: center;
	left: 16px;
	position: absolute;
	top: 16px;
	width: 58px;
}

.hh-ref-package-card__badge + .hh-ref-package-card__media .hh-ref-package-card__icon {
	top: 48px;
}

.hh-ref-package-card__icon--gold {
	background: var(--hh-gold);
}

.hh-ref-package-card__icon svg {
	fill: none;
	height: 31px;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.65;
	width: 31px;
}

.hh-ref-package-card__badge {
	background: var(--hh-gold);
	border-radius: 6px 6px 6px 0;
	color: var(--hh-white);
	font-size: 11px;
	font-weight: 700;
	left: 0;
	letter-spacing: 0.08em;
	line-height: 1;
	padding: 9px 14px;
	position: absolute;
	text-transform: uppercase;
	top: 0;
	z-index: 1;
}

.hh-ref-package-card__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 22px 24px 24px;
}

.hh-ref-package-card h3 {
	color: var(--hh-ink);
	font-family: var(--hh-serif);
	font-size: clamp(23px, 2.1vw, 30px);
	font-weight: 600;
	line-height: 1.05;
	margin: 0 0 8px;
	text-align: center;
}

.hh-ref-package-card__summary {
	color: rgba(42, 55, 35, 0.76) !important;
	font-size: 13px !important;
	line-height: 1.55 !important;
	margin: 0 auto 16px !important;
	max-width: 300px;
	text-align: center;
}

.hh-ref-package-card__price {
	margin: 0 auto 14px;
	text-align: center;
}

.hh-ref-package-card__price strong {
	color: var(--hh-ink);
	display: block;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.1;
}

.hh-ref-package-card__price strong span {
	color: var(--hh-muted);
	font-size: 13px;
	font-weight: 500;
}

.hh-ref-package-card__price > span {
	color: var(--hh-gold);
	display: block;
	font-size: 14px;
	font-weight: 700;
	margin-top: 4px;
}

.hh-ref-package-card__meta {
	align-items: center;
	color: rgba(42, 55, 35, 0.72);
	display: flex;
	flex-wrap: wrap;
	font-size: 13px;
	font-weight: 600;
	gap: 8px 16px;
	justify-content: center;
	margin-bottom: 16px;
	text-align: center;
}

.hh-ref-package-card__meta span {
	align-items: center;
	display: inline-flex;
	gap: 6px;
	white-space: nowrap;
}

.hh-ref-package-card__meta span::before {
	background: rgba(201, 154, 69, 0.7);
	border-radius: 999px;
	content: "";
	display: inline-block;
	height: 6px;
	width: 6px;
}

.hh-ref-package-card p {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.6;
	margin: 0 0 22px;
}

.hh-ref-package-card__list {
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	display: grid;
	gap: 8px;
	list-style: none;
	margin: 0 0 16px;
	padding: 16px 0 0;
}

.hh-ref-package-card__list li {
	color: var(--hh-muted);
	display: grid;
	font-size: 13px;
	gap: 9px;
	grid-template-columns: 18px minmax(0, 1fr);
	line-height: 1.45;
}

.hh-ref-package-card__list li::before {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 999px;
	color: var(--hh-white);
	content: "\2713";
	display: inline-flex;
	font-size: 10px;
	font-weight: 700;
	height: 16px;
	justify-content: center;
	line-height: 1;
	margin-top: 1px;
	width: 16px;
}

.hh-ref-package-card__notice {
	background: rgba(201, 154, 69, 0.14);
	border-radius: 8px;
	color: rgba(42, 55, 35, 0.82) !important;
	font-size: 12px !important;
	line-height: 1.55 !important;
	margin: 0 0 14px !important;
	padding: 12px 14px;
}

.hh-ref-package-card__tags {
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: auto;
	padding-top: 14px;
}

.hh-ref-package-card__tags span {
	background: rgba(73, 111, 53, 0.08);
	border: 1px solid rgba(73, 111, 53, 0.16);
	border-radius: 999px;
	color: rgba(42, 55, 35, 0.78);
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
	padding: 7px 9px;
}

.hh-ref-package-card__pickup {
	align-items: center;
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	color: rgba(42, 55, 35, 0.78) !important;
	display: flex;
	font-size: 12px !important;
	font-weight: 700;
	justify-content: center;
	line-height: 1.45 !important;
	margin: 16px 0 16px !important;
	padding: 12px 0;
	text-align: center;
}

.hh-ref-package-card__footer {
	align-items: center;
	display: flex;
	gap: 18px;
	justify-content: space-between;
	margin-top: auto;
}

.hh-ref-package-card__footer strong {
	color: var(--hh-ink);
	font-size: 23px;
	font-weight: 700;
	line-height: 1;
	white-space: nowrap;
}

.hh-ref-package-card__footer strong span {
	color: var(--hh-muted);
	font-size: 13px;
	font-weight: 500;
}

.hh-ref-package-card__footer a {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 8px;
	color: var(--hh-white) !important;
	display: inline-flex;
	font-size: 13px;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.04em;
	min-height: 48px;
	padding: 12px 18px;
	text-decoration: none !important;
	text-transform: uppercase;
	white-space: nowrap;
	width: 100%;
}

.hh-ref-package-card__footer a::after {
	content: "\2192";
	font-size: 18px;
	line-height: 1;
	margin-left: 10px;
}

.hh-ref-photo-gallery {
	background:
		linear-gradient(180deg, rgba(250, 244, 232, 0.88), rgba(255, 253, 248, 0.96)),
		var(--hh-paper);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(54px, 7vw, 88px) 24px;
}

body.happy-herb-redesign.page-id-11 .elementor-element-585d983c {
	display: none !important;
}

.hh-ref-photo-gallery__inner {
	margin-inline: auto;
	max-width: 1240px;
}

.hh-ref-photo-gallery__heading {
	align-items: end;
	display: grid;
	gap: 24px;
	grid-template-columns: minmax(280px, 440px) minmax(320px, 1fr);
	margin-bottom: clamp(24px, 3vw, 36px);
}

.hh-ref-photo-gallery__heading span {
	color: var(--hh-gold);
	display: block;
	font-family: var(--hh-script);
	font-size: clamp(32px, 3.4vw, 44px);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 8px;
}

.hh-ref-photo-gallery__heading h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(36px, 3.8vw, 54px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.02;
	margin: 0;
}

.hh-ref-photo-gallery__heading p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.7;
	margin: 0;
	max-width: 620px;
}

.hh-ref-photo-gallery__grid {
	display: grid;
	gap: clamp(14px, 1.7vw, 22px);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.hh-ref-photo-gallery__item {
	aspect-ratio: 4 / 3;
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	box-shadow: 0 18px 40px rgba(42, 55, 35, 0.1);
	margin: 0;
	overflow: hidden;
	position: relative;
}

.hh-ref-photo-gallery__item--large {
	grid-column: auto;
	grid-row: auto;
}

.hh-ref-photo-gallery__item--wide {
	grid-column: auto;
}

.hh-ref-photo-gallery__item--tall {
	grid-row: auto;
}

.hh-ref-photo-gallery__item a,
.hh-ref-photo-gallery__item img {
	display: block;
	height: 100%;
	width: 100%;
}

.hh-ref-photo-gallery__item img {
	object-fit: cover;
	transition: transform 260ms ease;
}

.hh-ref-photo-gallery__item:hover img {
	transform: scale(1.04);
}

.hh-ref-photo-gallery__footer {
	display: flex;
	justify-content: center;
	margin-top: 28px;
}

.hh-ref-photo-gallery__footer a {
	align-items: center;
	background: transparent;
	border: 1px solid rgba(31, 78, 46, 0.32);
	border-radius: 8px;
	color: var(--hh-deep-2) !important;
	display: inline-flex;
	font-size: 13px;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.04em;
	min-height: 46px;
	padding: 12px 24px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ref-photo-gallery__footer a:hover {
	background: var(--hh-moss);
	border-color: var(--hh-moss);
	color: var(--hh-white) !important;
}

.hh-ref-faq {
	background: var(--hh-warm-paper);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(58px, 7vw, 92px) 24px;
}

.hh-ref-faq__inner {
	display: grid;
	gap: clamp(28px, 5vw, 72px);
	grid-template-columns: minmax(260px, 390px) minmax(520px, 1fr);
	margin-inline: auto;
	max-width: 1180px;
}

.hh-ref-faq__heading span {
	color: var(--hh-gold);
	display: block;
	font-family: var(--hh-script);
	font-size: clamp(30px, 3vw, 42px);
	line-height: 1;
	margin-bottom: 8px;
}

.hh-ref-faq__heading h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(34px, 3.7vw, 50px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0 0 16px;
}

.hh-ref-faq__heading p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.7;
	margin: 0;
}

.hh-ref-faq__list {
	display: grid;
	gap: 12px;
}

.hh-ref-faq__item {
	background: rgba(255, 253, 248, 0.72);
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 8px;
	overflow: hidden;
}

.hh-ref-faq__item summary {
	align-items: center;
	color: var(--hh-deep-2);
	cursor: pointer;
	display: flex;
	font-family: var(--hh-sans);
	font-size: 16px;
	font-weight: 700;
	gap: 16px;
	justify-content: space-between;
	line-height: 1.35;
	list-style: none;
	padding: 20px 22px;
}

.hh-ref-faq__item summary::-webkit-details-marker {
	display: none;
}

.hh-ref-faq__item summary::after {
	color: var(--hh-gold);
	content: "+";
	flex: 0 0 auto;
	font-size: 24px;
	font-weight: 500;
	line-height: 1;
}

.hh-ref-faq__item[open] summary::after {
	content: "-";
}

.hh-ref-faq__item p {
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.7;
	margin: 0;
	padding: 0 22px 22px;
}

.hh-ref-final-cta {
	background:
		repeating-linear-gradient(135deg, rgba(255, 253, 248, 0.035) 0 1px, transparent 1px 12px),
		linear-gradient(90deg, rgba(12, 25, 11, 0.98), rgba(33, 56, 29, 0.98)),
		var(--hh-deep-2);
	color: var(--hh-white);
	overflow: hidden;
	padding: clamp(76px, 9vw, 118px) 24px;
	position: relative;
	text-align: center;
}

.hh-ref-final-cta__inner {
	margin-inline: auto;
	max-width: 560px;
	position: relative;
}

.hh-ref-final-cta__eyebrow {
	color: var(--hh-gold);
	font-family: var(--hh-script);
	font-size: clamp(30px, 3.2vw, 46px);
	line-height: 1;
	margin: 0 0 10px;
}

.hh-ref-final-cta h2 {
	color: var(--hh-white);
	font-family: var(--hh-serif);
	font-size: clamp(36px, 4.2vw, 58px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 0.98;
	margin: 0 auto 22px;
	max-width: 520px;
}

.hh-ref-final-cta__inner > p:not(.hh-ref-final-cta__eyebrow) {
	color: rgba(255, 253, 248, 0.78);
	font-size: 15px;
	line-height: 1.7;
	margin: 0 auto;
	max-width: 470px;
}

.hh-ref-final-cta__actions {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	justify-content: center;
	margin-top: 32px;
}

.hh-ref-final-cta__button {
	align-items: center;
	border-radius: 8px;
	display: inline-flex;
	font-size: 14px;
	font-weight: 700;
	gap: 9px;
	justify-content: center;
	line-height: 1.1;
	min-height: 52px;
	min-width: 204px;
	padding: 15px 22px;
	text-decoration: none !important;
	transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.hh-ref-final-cta__button:hover {
	transform: translateY(-1px);
}

.hh-ref-final-cta__button--primary {
	background: var(--hh-gold);
	border: 1px solid var(--hh-gold);
	color: var(--hh-white) !important;
	box-shadow: 0 14px 26px rgba(8, 16, 8, 0.22);
}

.hh-ref-final-cta__button--primary:hover {
	background: #d1a452;
	border-color: #d1a452;
	color: var(--hh-white) !important;
}

.hh-ref-final-cta__button--secondary {
	background: rgba(255, 253, 248, 0.96);
	border: 1px solid rgba(255, 253, 248, 0.82);
	color: var(--hh-deep-2) !important;
}

.hh-ref-final-cta__button--secondary:hover {
	background: var(--hh-white);
	color: var(--hh-forest) !important;
}

.hh-ref-final-cta__button-icon {
	display: inline-flex;
	height: 17px;
	width: 17px;
}

.hh-ref-final-cta__button-icon svg {
	fill: none;
	height: 100%;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.8;
	width: 100%;
}

.hh-ref-video {
	background: var(--hh-deep-2);
	color: rgba(255, 253, 248, 0.82);
	padding: clamp(42px, 6vw, 72px) 24px;
}

.hh-ref-video__inner {
	align-items: center;
	display: grid;
	gap: clamp(28px, 5vw, 64px);
	grid-template-columns: minmax(280px, 390px) minmax(520px, 1fr);
	margin-inline: auto;
	max-width: 1240px;
}

.hh-ref-video__copy span {
	color: var(--hh-gold);
	display: block;
	font-family: var(--hh-script);
	font-size: clamp(34px, 3.5vw, 46px);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 8px;
}

.hh-ref-video__copy h2 {
	color: var(--hh-white);
	font-family: var(--hh-serif);
	font-size: clamp(34px, 3.8vw, 52px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0 0 16px;
}

.hh-ref-video__copy p {
	color: rgba(255, 253, 248, 0.75);
	font-size: 15px;
	line-height: 1.7;
	margin: 0;
}

.hh-ref-video__preview {
	appearance: none;
	background: transparent;
	border: 1px solid rgba(255, 253, 248, 0.2);
	border-radius: 8px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.28);
	cursor: pointer;
	display: block;
	margin: 0;
	overflow: hidden;
	padding: 0;
	position: relative;
	width: 100%;
}

.hh-ref-video__preview::after {
	background: linear-gradient(180deg, rgba(11, 25, 10, 0.08), rgba(11, 25, 10, 0.36));
	content: "";
	inset: 0;
	position: absolute;
}

.hh-ref-video__preview img {
	aspect-ratio: 1.85;
	display: block;
	height: auto;
	object-fit: cover;
	transform: scale(1.01);
	transition: transform 220ms ease;
	width: 100%;
}

.hh-ref-video__preview:hover img {
	transform: scale(1.04);
}

.hh-ref-video__play {
	align-items: center;
	background: rgba(255, 253, 248, 0.95);
	border-radius: 999px;
	box-shadow: 0 16px 34px rgba(0, 0, 0, 0.24);
	color: var(--hh-deep-2);
	display: inline-flex;
	height: 72px;
	justify-content: center;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 72px;
	z-index: 1;
}

.hh-ref-video__play::before {
	border-bottom: 13px solid transparent;
	border-left: 18px solid currentColor;
	border-top: 13px solid transparent;
	content: "";
	margin-left: 5px;
}

.hh-ref-video-modal[hidden] {
	display: none;
}

.hh-ref-video-modal {
	align-items: center;
	display: flex;
	inset: 0;
	justify-content: center;
	padding: 24px;
	position: fixed;
	z-index: 999999;
}

.hh-ref-video-modal__backdrop {
	background: rgba(5, 16, 8, 0.78);
	border: 0;
	cursor: pointer;
	inset: 0;
	padding: 0;
	position: absolute;
}

.hh-ref-video-modal__panel {
	background: #07130a;
	border: 1px solid rgba(255, 253, 248, 0.2);
	border-radius: 8px;
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.45);
	max-width: min(980px, calc(100vw - 32px));
	overflow: hidden;
	position: relative;
	width: 100%;
	z-index: 1;
}

.hh-ref-video-modal__header {
	align-items: center;
	display: flex;
	justify-content: space-between;
	padding: 16px 18px;
}

.hh-ref-video-modal__header h2 {
	color: var(--hh-white);
	font-family: var(--hh-serif);
	font-size: 24px;
	font-weight: 600;
	line-height: 1.1;
	margin: 0;
}

.hh-ref-video-modal__close {
	align-items: center;
	background: rgba(255, 253, 248, 0.1);
	border: 1px solid rgba(255, 253, 248, 0.18);
	border-radius: 999px;
	color: var(--hh-white);
	cursor: pointer;
	display: inline-flex;
	font-size: 28px;
	height: 42px;
	justify-content: center;
	line-height: 1;
	padding: 0 0 3px;
	width: 42px;
}

.hh-ref-video-modal__media {
	aspect-ratio: 16 / 9;
	display: block;
	height: auto;
	max-height: calc(100vh - 160px);
	width: 100%;
}

.hh-ref-video-modal__media video {
	display: block;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.hh-ref-hero__title {
	font-size: clamp(34px, 4.05vw, 54px);
	font-weight: 500;
	line-height: 1.08;
	max-width: 620px;
	text-shadow: 0 2px 7px rgba(0, 0, 0, 0.32);
}

.hh-ref-hero__script {
	font-size: clamp(30px, 3.3vw, 43px);
	font-weight: 500;
	margin: 10px 0 18px;
}

.hh-ref-license__copy h2,
.hh-ref-story__copy h2,
.hh-ref-why__copy h2,
.hh-ref-section-heading h2,
.hh-ref-photo-gallery__heading h2,
.hh-ref-faq__heading h2,
.hh-ref-final-cta h2,
.hh-ref-video__copy h2 {
	font-weight: 500;
}

.hh-ref-story__copy h2,
.hh-ref-why__copy h2,
.hh-ref-section-heading h2,
.hh-ref-faq__heading h2,
.hh-ref-video__copy h2 {
	font-size: clamp(30px, 3.05vw, 42px);
	line-height: 1.1;
}

.hh-ref-photo-gallery__heading h2,
.hh-ref-final-cta h2 {
	font-size: clamp(32px, 3.35vw, 48px);
	line-height: 1.08;
}

.hh-ref-license__copy h2 {
	font-size: clamp(30px, 2.8vw, 40px);
	line-height: 1.08;
}

.hh-ref-package-card h3 {
	font-size: clamp(22px, 1.85vw, 27px);
	font-weight: 500;
	line-height: 1.12;
}

.hh-ref-button,
.hh-ref-story__button,
.hh-ref-package-card__footer a,
.hh-ref-final-cta__button,
.hh-ref-license__link,
.hh-ref-footer-brand__button {
	font-weight: 600;
}

.hh-ref-hero__proof-copy strong,
.hh-ref-benefit strong,
.hh-ref-package-card__price strong,
.hh-ref-package-card__price > span,
.hh-ref-faq__item summary {
	font-weight: 600;
}

.hh-ref-license__inner {
	gap: clamp(26px, 3.4vw, 46px);
	grid-template-columns: minmax(160px, 220px) minmax(360px, 1.16fr) minmax(340px, 0.9fr);
	max-width: 1180px;
	padding: clamp(26px, 3.2vw, 38px) clamp(34px, 4.2vw, 54px) clamp(26px, 3.2vw, 38px) clamp(26px, 3vw, 36px);
}

.hh-ref-license__verification {
	min-width: 0;
	padding-right: 8px;
}

.hh-ref-license__details div {
	grid-template-columns: minmax(132px, 0.58fr) minmax(0, 1fr);
}

.hh-ref-license__details dd {
	overflow-wrap: anywhere;
}

.hh-ref-license__link {
	justify-self: stretch;
	max-width: 100%;
	white-space: normal;
}

.hh-ref-video-is-open {
	overflow: hidden;
}

body.happy-herb-redesign.page-id-11 .elementor-element-230e1b10 {
	background: var(--hh-warm-paper) !important;
	padding-block: clamp(70px, 9vw, 112px) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-dd264d1 .elementor-heading-title,
body.happy-herb-redesign.page-id-11 .elementor-element-d546abc .elementor-heading-title,
body.happy-herb-redesign.page-id-11 .elementor-element-f6077de .elementor-heading-title,
body.happy-herb-redesign.page-id-11 .elementor-element-3c6ce61 .elementor-heading-title {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-weight: 600;
}

body.happy-herb-redesign.page-id-11 .elementor-element-dd264d1 .elementor-heading-title {
	font-size: clamp(38px, 4.8vw, 60px);
	line-height: 1.02;
}

body.happy-herb-redesign.page-id-11 .elementor-element-1de2a7ef {
	background: #fffaf0 !important;
	padding-block: clamp(70px, 9vw, 112px) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-1de2a7ef .elementor-widget-image img,
body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4 .elementor-widget-image img,
body.happy-herb-redesign .elementor-widget-gallery img {
	border-radius: 8px;
}

body.happy-herb-redesign.page-id-11 .elementor-element-291bab3 .elementor-icon-list-item {
	background: transparent;
	border: 0;
	box-shadow: none;
	color: var(--hh-deep);
	font-size: 15px;
	margin-bottom: 8px;
	padding: 0;
}

body.happy-herb-redesign.page-id-11 .elementor-element-291bab3 .elementor-icon-list-icon {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 50%;
	color: var(--hh-white);
	display: inline-flex;
	height: 20px;
	justify-content: center;
	margin-right: 10px;
	width: 20px;
}

body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4 {
	background: var(--hh-cream) !important;
	padding-block: clamp(74px, 9vw, 118px) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4 .elementor-widget-image {
	background: var(--hh-white);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	box-shadow: 0 14px 34px rgba(22, 35, 27, 0.1);
	overflow: hidden;
}

body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4 .elementor-widget-button .elementor-button {
	background: #315823;
	border-color: #315823;
	border-radius: 7px;
	box-shadow: none;
	min-height: 44px;
	padding-inline: 22px;
}

body.happy-herb-redesign.page-id-11 .elementor-element-074e0b4 .elementor-widget-button .elementor-button:hover {
	background: var(--hh-gold);
	border-color: var(--hh-gold);
}

body.happy-herb-redesign.page-id-11 .elementor-element-585d983c {
	background: var(--hh-warm-paper) !important;
	padding-block: clamp(70px, 9vw, 104px) !important;
}

body.happy-herb-redesign.page-id-11 .elementor-element-585d983c .elementor-widget-gallery,
body.happy-herb-redesign.page-id-11 .elementor-element-585d983c .elementor-widget-image-gallery {
	border-radius: 8px;
	overflow: hidden;
}

@media (max-width: 959px) {
	body.happy-herb-redesign.page-id-11 #site-header {
		background: rgba(19, 35, 18, 0.96);
		position: sticky;
	}

	.hh-ref-hero,
	.hh-ref-hero__inner {
		min-height: 560px;
	}

	.hh-ref-hero {
		--hh-ref-hero-height: 560px;
	}

	.hh-ref-hero__inner {
		padding: 86px 28px 42px;
	}

	.hh-ref-hero__shade {
		background: linear-gradient(90deg, rgba(11, 25, 10, 0.92), rgba(11, 25, 10, 0.58));
	}

	.hh-ref-hero__proof {
		max-width: calc(100vw - 56px);
	}

	.hh-ref-hero__proof-item {
		gap: 8px;
		padding: 0 12px;
	}

	.hh-ref-hero__proof-icon {
		height: 32px;
		width: 32px;
	}

	.hh-ref-benefits__inner {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		padding: 20px;
	}

	.hh-ref-benefit {
		border-bottom: 1px solid rgba(31, 78, 46, 0.12);
		border-right: 0;
	}

	.hh-ref-trust__inner {
		grid-template-columns: 1fr;
		justify-items: center;
		text-align: center;
	}

	.hh-ref-trust__label br {
		display: none;
	}

	.hh-ref-trust__logos {
		justify-content: center;
	}

	.hh-ref-trust__rating {
		align-items: center;
		justify-self: center;
		text-align: center;
	}

	.hh-ref-reviews__header {
		grid-template-columns: 1fr;
		justify-items: center;
	}

	.hh-ref-reviews__score {
		justify-self: center;
		text-align: center;
	}

	.hh-ref-review-row__header {
		grid-template-columns: 1fr;
		justify-items: center;
		text-align: center;
	}

	.hh-ref-reviews__cards {
		gap: 16px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-ref-review-card {
		min-height: 200px;
		padding: 16px;
	}

	.hh-ref-license__inner {
		align-items: start;
		grid-template-columns: minmax(180px, 230px) minmax(0, 1fr);
	}

	.hh-ref-license__verification {
		grid-column: 1 / -1;
	}

	.hh-ref-license__details {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.hh-ref-license__details div {
		border-bottom: 0;
		border-right: 1px solid rgba(31, 78, 46, 0.1);
		grid-template-columns: 1fr;
		padding: 0 18px 0 0;
	}

	.hh-ref-license__details div:last-child {
		border-right: 0;
		padding-right: 0;
	}

	.hh-ref-license__link {
		justify-self: start;
		white-space: normal;
	}

	.hh-ref-story__inner {
		grid-template-columns: 220px minmax(0, 1fr);
	}

	.hh-ref-story__features {
		grid-column: 1 / -1;
	}

	.hh-ref-why__inner {
		grid-template-columns: 1fr;
	}

	.hh-ref-why__copy {
		max-width: 620px;
	}

	.hh-ref-video__inner {
		grid-template-columns: 1fr;
	}

	.hh-ref-video__copy {
		max-width: 620px;
	}

	.hh-ref-faq__inner {
		grid-template-columns: 1fr;
	}

	.hh-ref-faq__heading {
		max-width: 620px;
	}

	.hh-ref-package-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-ref-package-card:last-child {
		grid-column: 1 / -1;
	}

	.hh-ref-photo-gallery__heading {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.hh-ref-photo-gallery__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-ref-photo-gallery__item--large,
	.hh-ref-photo-gallery__item--wide,
	.hh-ref-photo-gallery__item--tall {
		grid-column: auto;
		grid-row: auto;
	}

	.hh-ref-footer-utility__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-ref-footer-utility__group {
		border-bottom: 1px solid rgba(255, 253, 248, 0.18);
		border-right: 0;
		min-height: 0;
		padding: 24px 0;
	}

	.hh-ref-footer-pickup {
		align-items: center;
		grid-template-columns: minmax(0, 1fr) minmax(104px, 138px);
	}

	.hh-ref-footer-utility__group:first-child,
	.hh-ref-footer-utility__group:nth-child(2) {
		padding-top: 0;
	}

	.hh-ref-footer-utility__group:nth-last-child(-n+2) {
		border-bottom: 0;
		padding-bottom: 0;
	}

	.hh-ref-footer-main__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.hh-ref-hero,
	.hh-ref-hero__inner {
		min-height: 520px;
	}

	.hh-ref-hero {
		--hh-ref-hero-height: 520px;
	}

	.hh-ref-hero::before {
		background-position: 62% center;
	}

	.hh-ref-hero__inner {
		padding: 76px 20px 34px;
	}

	.hh-ref-hero__title {
		font-size: clamp(36px, 10vw, 48px);
	}

	.hh-ref-hero__script {
		font-size: 30px;
	}

	.hh-ref-button {
		width: 100%;
	}

	.hh-ref-hero__proof {
		align-items: stretch;
		flex-direction: column;
		gap: 12px;
		max-width: 100%;
		width: 100%;
	}

	.hh-ref-hero__proof-item {
		border-bottom: 1px solid rgba(255, 255, 255, 0.22);
		border-right: 0;
		padding: 0 0 12px;
		width: 100%;
	}

	.hh-ref-hero__proof-item:last-child {
		border-bottom: 0;
		padding-bottom: 0;
	}

	.hh-ref-benefits__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-ref-trust__inner {
		padding: 26px 20px;
	}

	.hh-ref-trust__logos {
		flex-wrap: wrap;
		gap: 18px 24px;
	}

	.hh-ref-reviews {
		padding-inline: 18px;
	}

	.hh-ref-reviews__header {
		margin-bottom: 20px;
	}

	.hh-ref-reviews__score strong {
		font-size: 21px;
	}

	.hh-ref-review-row__header h3 {
		font-size: 21px;
	}

	.hh-ref-reviews__cards {
		grid-template-columns: 1fr;
	}

	.hh-ref-review-row__source-link {
		width: auto;
	}

	.hh-ref-review-card {
		min-height: 0;
	}

	.hh-ref-license {
		padding-inline: 18px;
	}

	.hh-ref-license__inner {
		grid-template-columns: 1fr;
		padding: 24px;
	}

	.hh-ref-license__document {
		margin-inline: auto;
		max-width: 220px;
	}

	.hh-ref-license__document-label {
		right: -6px;
		top: 14px;
	}

	.hh-ref-license__details {
		grid-template-columns: 1fr;
	}

	.hh-ref-license__details div {
		border-bottom: 1px solid rgba(31, 78, 46, 0.1);
		border-right: 0;
		grid-template-columns: 1fr;
		padding: 0 0 12px;
	}

	.hh-ref-license__details div:last-child {
		border-bottom: 0;
		padding-bottom: 0;
	}

	.hh-ref-license__link {
		justify-self: stretch;
		width: 100%;
	}

	.hh-ref-story {
		padding-inline: 18px;
	}

	.hh-ref-story__inner {
		grid-template-columns: 1fr;
	}

	.hh-ref-story__founder {
		margin-inline: auto;
		max-width: 260px;
		width: 100%;
	}

	.hh-ref-story__features {
		grid-template-columns: 1fr;
	}

	.hh-ref-story__feature,
	.hh-ref-story__feature:nth-child(odd),
	.hh-ref-story__feature:nth-last-child(-n+2) {
		border-bottom: 1px solid rgba(31, 78, 46, 0.1);
		border-right: 0;
	}

	.hh-ref-story__feature:last-child {
		border-bottom: 0;
	}

	.hh-ref-story__feature {
		grid-template-columns: 42px minmax(0, 1fr);
		padding: 24px;
	}

	.hh-ref-story__number {
		font-size: 22px;
	}

	.hh-ref-why,
	.hh-ref-packages,
	.hh-ref-photo-gallery {
		padding-inline: 18px;
	}

	.hh-ref-why__gallery {
		grid-template-columns: 1fr;
		grid-template-rows: auto;
		height: auto;
		min-height: 0;
	}

	.hh-ref-why__image--main {
		aspect-ratio: 1.18;
		grid-row: auto;
	}

	.hh-ref-why__image:not(.hh-ref-why__image--main) {
		aspect-ratio: 1.35;
	}

	.hh-ref-video {
		padding-inline: 18px;
	}

	.hh-ref-faq {
		padding-inline: 18px;
	}

	.hh-ref-final-cta {
		padding: 64px 18px;
	}

	.hh-ref-final-cta__actions {
		align-items: stretch;
		flex-direction: column;
		margin-inline: auto;
		max-width: 320px;
	}

	.hh-ref-final-cta__button {
		min-width: 0;
		width: 100%;
	}

	.hh-ref-faq__item summary {
		font-size: 15px;
		padding: 18px 18px;
	}

	.hh-ref-faq__item p {
		padding: 0 18px 18px;
	}

	.hh-ref-video__preview img {
		aspect-ratio: 1.18;
	}

	.hh-ref-video__play {
		height: 60px;
		width: 60px;
	}

	.hh-ref-video-modal {
		padding: 14px;
	}

	.hh-ref-video-modal__header {
		padding: 12px;
	}

	.hh-ref-video-modal__header h2 {
		font-size: 20px;
	}

	.hh-ref-video-modal__close {
		height: 38px;
		width: 38px;
	}

	.hh-ref-video-modal__media {
		max-height: calc(100vh - 112px);
	}

	.hh-ref-package-grid {
		grid-template-columns: 1fr;
	}

	.hh-ref-package-card:last-child {
		grid-column: auto;
	}

	.hh-ref-package-card__footer {
		align-items: stretch;
		flex-direction: column;
	}

	.hh-ref-package-card__footer a {
		width: 100%;
	}

	.hh-ref-photo-gallery__grid {
		gap: 14px;
		grid-template-columns: 1fr;
	}

	.hh-ref-photo-gallery__item {
		aspect-ratio: 1.32;
	}

	.hh-ref-photo-gallery__footer a {
		width: 100%;
	}

	.hh-ref-footer-utility__inner,
	.hh-ref-footer-main__inner {
		grid-template-columns: 1fr;
		padding-inline: 18px;
	}

	.hh-ref-footer-map-link__copy {
		align-items: start;
		display: grid;
		gap: 2px;
	}

	.hh-ref-footer-map-link__copy > span,
	.hh-ref-footer-map-link__copy small {
		white-space: normal;
	}

	.hh-ref-footer-utility__group,
	.hh-ref-footer-utility__group:first-child,
	.hh-ref-footer-utility__group:nth-child(2),
	.hh-ref-footer-utility__group:nth-last-child(-n+2),
	.hh-ref-footer-utility__group:last-child {
		border-bottom: 1px solid rgba(255, 253, 248, 0.18);
		border-right: 0;
		padding: 0 0 22px;
	}

	.hh-ref-footer-utility__group:not(:first-child) {
		pad
}
}
/* ===== Unified dark header on all inner pages (matches the Home header skin) ===== */
body.happy-herb-redesign.hh-ref-header-dark:not(.page-id-11) #site-header {
	background: rgba(19, 35, 18, 0.98);
	border-bottom: 1px solid rgba(255, 253, 248, 0.08);
	box-shadow: 0 8px 24px rgba(8, 16, 9, 0.25);
}

/* Inner header template (ID 328) uses different element ids than the front
   page template (ID 38); mirror the desktop layout rules so both render
   identically: flex row, centered, search widget hidden. */
@media (min-width: 960px) {
	body.happy-herb-redesign .elementor-location-header .elementor-element-64f7ee8 > .e-con-inner {
		align-items: center;
		display: flex;
		gap: clamp(18px, 2vw, 34px);
		max-width: 1320px;
		width: 100%;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-6f8837e {
		flex: 0 0 auto;
		width: auto;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-5ed8a81 {
		flex: 1 1 auto;
		min-width: 0;
		width: auto;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-cacc3b8 {
		display: none !important;
	}
}

/* ===== WP Travel Engine brand skin =====
   The plugin colors everything (buttons, calendar, steps, checkout)
   from --primary-color, so overriding it at body level re-skins the
   whole booking flow to the Happy Herb forest green. */
body.happy-herb-redesign {
	--primary-color: #496F35;
	--primary-color-rgb: 73, 111, 53;
	--font-family: "DM Sans", sans-serif;
}

/* Buttons: brand radius + typography (plugin default is a 100px pill) */
body.happy-herb-redesign .wpte-bf-btn,
body.happy-herb-redesign .wpte-button,
body.happy-herb-redesign .wte-process-btn,
body.happy-herb-redesign .wpte-bf-modal button[type="submit"] {
	border-radius: 8px !important;
	font-family: "DM Sans", sans-serif;
	font-weight: 600;
	letter-spacing: 0.2px;
}

body.happy-herb-redesign .wpte-bf-btn:hover,
body.happy-herb-redesign .wte-process-btn:hover,
body.happy-herb-redesign .wpte-button:hover {
	background-color: #20351D !important;
	border-color: #20351D !important;
}

/* Trip title + section headings follow the master typography */
body.happy-herb-redesign.single-trip h1.entry-title {
	color: #20351D;
}

body.happy-herb-redesign .wpte-trip-content-area h2,
body.happy-herb-redesign .wpte-trip-content-area h3,
body.happy-herb-redesign .wpte-booking-area h2,
body.happy-herb-redesign .wpte-tabs-wrapper h2,
body.happy-herb-redesign .wpte-tabs-wrapper h3 {
	color: #20351D;
	font-family: "Cormorant Garamond", "Georgia", serif;
}

/* Price block */
body.happy-herb-redesign .wpte-bf-price-wrap .wpte-bf-offer-amount,
body.happy-herb-redesign .wpte-bf-price-wrap .wpte-bf-price {
	color: #20351D;
}

body.happy-herb-redesign .wpte-bf-price-from {
	color: #C9973F;
}

/* ===== Trust band: white brand logos ===== */
.hh-ref-trust__logos--brand {
	align-items: center;
	display: flex;
	flex-wrap: nowrap;
	gap: clamp(20px, 2.4vw, 40px);
	justify-content: center;
	min-width: 0;
}

.hh-ref-trust__logos--brand .hh-tl {
	align-items: center;
	display: inline-flex;
	line-height: 1;
	white-space: nowrap;
}

.hh-ref-trust__logos--brand .hh-tl img {
	display: block;
	max-width: none;
	object-fit: contain;
	width: auto;
}

.hh-ref-trust__logos--brand .hh-tl--viator img {
	height: 25px;
}

.hh-ref-trust__logos--brand .hh-tl--gyg img {
	height: 48px;
}

.hh-ref-trust__logos--brand .hh-tl--ta img {
	height: 25px;
}

.hh-ref-trust__logos--brand .hh-tl--klook img {
	height: 30px;
}

.hh-ref-trust__logos--brand .hh-tl--tmt img {
	height: 19px;
}

@media (max-width: 767px) {
	.hh-ref-trust__logos--brand {
		flex-wrap: wrap;
		row-gap: 14px;
	}
}

/* ===== Unified navigation typography =====
   The two header templates (38/328) shipped different menu font sizes
   (13px vs 10.5px) and the Farm Updates virtual page lost the serif
   family. One rule normalizes every page and bumps the size slightly. */
body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .elementor-item {
	font-family: "Cormorant Garamond", "Georgia", serif !important;
	font-size: 14.5px !important;
	letter-spacing: 0.3px !important;
}

@media (min-width: 960px) {
	body.happy-herb-redesign .elementor-location-header .elementor-element-6c5ffe2 > .e-con-inner,
	body.happy-herb-redesign .elementor-location-header .elementor-element-64f7ee8 > .e-con-inner {
		align-items: center;
		gap: clamp(18px, 2vw, 29px);
		max-width: 1320px;
		min-height: 82px;
		padding-bottom: 0;
		width: 100%;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-3ddb3ab,
	body.happy-herb-redesign .elementor-location-header .elementor-element-6f8837e {
		flex: 0 0 224px !important;
		width: 224px !important;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-element-e5a8f76,
	body.happy-herb-redesign .elementor-location-header .elementor-element-5ed8a81 {
		flex: 1 1 auto !important;
		min-width: 0;
		width: auto !important;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-widget-image img {
		height: 46px;
		width: 46px;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-widget-image a {
		column-gap: 8px;
		grid-template-columns: 46px minmax(96px, auto);
		min-width: 168px;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-widget-image a::after {
		font-size: 18px;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-widget-image a::before {
		font-size: 7px;
		letter-spacing: 0.1em;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .elementor-nav-menu {
		gap: 0;
		justify-content: flex-end;
		width: 100%;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .elementor-item {
		padding: 9px 5px !important;
	}

	body.happy-herb-redesign .elementor-location-header .hh-ref-nav-book-now > .elementor-item {
		flex: 0 0 92px !important;
		font-size: 11px !important;
		margin: 0 10px 0 4px !important;
		min-width: 92px !important;
		padding: 11px 10px !important;
		width: 92px !important;
	}

	body.hh-partners-page .elementor-location-header .hh-ref-nav-book-now > .elementor-item {
		flex-basis: auto !important;
		min-width: 174px !important;
		width: auto !important;
	}

	body.happy-herb-redesign .elementor-location-header .elementor-nav-menu--main .hh-ref-nav-whatsapp > .elementor-item {
		height: 36px;
		margin-left: 5px;
		min-width: 36px;
		width: 36px;
	}

	body.happy-herb-redesign .elementor-location-header .hh-ref-nav-whatsapp svg {
		height: 19px;
		width: 19px;
	}

	body.happy-herb-redesign.hh-ref-farm-updates-page #site-header {
		border-bottom: 0 !important;
	}
}

@media (max-width: 767px) {
	.hh-ref-trust__label br {
		display: block !important;
	}
}

/* ===================== CONTACT PAGE (mockup aligned) ===================== */
body.happy-herb-redesign.page-id-22 .site-main {
	background: #fffdf8;
}

body.happy-herb-redesign.page-id-22 #site-header {
	background: linear-gradient(180deg, rgba(13, 28, 12, 0.78), rgba(13, 28, 12, 0.2));
	border: 0;
	box-shadow: none;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

body.admin-bar.happy-herb-redesign.page-id-22 #site-header {
	top: 32px;
}

.hh-ct-contact-hero::before {
	background-position: 50% 26%;
}

.hh-ct-help,
.hh-ct-exp,
.hh-ct-reviews {
	background:
		radial-gradient(circle at 16% 10%, rgba(201, 154, 69, 0.08), transparent 28%),
		linear-gradient(180deg, rgba(255, 253, 248, 0.96), rgba(251, 246, 236, 0.98)),
		var(--hh-paper);
}

.hh-ct-help {
	padding: 52px 0 42px;
}

.hh-ct-help__inner {
	display: grid;
	gap: 28px;
	grid-template-columns: minmax(0, 1.08fr) minmax(440px, 0.92fr);
	margin-inline: auto;
	max-width: 1180px;
	padding: 0 32px;
}

.hh-ct-help__concierge,
.hh-ct-help__channels {
	display: grid;
	gap: 20px;
	min-width: 0;
}

.hh-ct-help__concierge {
	align-items: center;
	grid-template-columns: minmax(220px, 0.88fr) minmax(240px, 1.12fr);
}

.hh-ct-help__channels {
	align-items: stretch;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hh-ct-help__photo {
	aspect-ratio: 4 / 5;
	border: 1px solid rgba(201, 154, 69, 0.2);
	border-radius: 8px;
	box-shadow: 0 18px 40px rgba(42, 55, 35, 0.13);
	margin: 0;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.hh-ct-help__photo::after {
	border: 1px solid rgba(255, 253, 248, 0.58);
	border-radius: 6px;
	content: "";
	inset: 8px;
	pointer-events: none;
	position: absolute;
}

.hh-ct-help__photo img,
.hh-ct-exp__media img,
.hh-ct-cta__image img,
.hh-ct-review img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.hh-ct-help__intro {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-width: 0;
}

.hh-ct-kicker {
	align-items: center;
	color: var(--hh-gold);
	display: inline-flex;
	font-size: 12px;
	font-weight: 600;
	gap: 10px;
	letter-spacing: 0.12em;
	line-height: 1;
	margin-bottom: 12px;
	text-transform: uppercase;
}

.hh-ct-kicker::after {
	background: rgba(201, 154, 69, 0.56);
	content: "";
	display: inline-block;
	height: 1px;
	width: 42px;
}

.hh-ct-help__intro h2,
.hh-ct-panel h2,
.hh-ct-cta__copy h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0;
}

.hh-ct-help__intro h2 {
	font-size: 34px;
	margin-bottom: 14px;
}

.hh-ct-help__intro p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.68;
	margin: 0 0 12px;
}

.hh-ct-help__quick {
	display: grid;
	gap: 8px;
	margin: 6px 0 14px;
}

.hh-ct-help__quick div {
	align-items: flex-start;
	background: rgba(255, 253, 248, 0.72);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	display: grid;
	gap: 2px 9px;
	grid-template-columns: 28px minmax(0, 1fr);
	padding: 10px 12px;
}

.hh-ct-help__quick span {
	align-items: center;
	background: rgba(201, 154, 69, 0.14);
	border-radius: 50%;
	color: var(--hh-moss);
	display: flex;
	grid-row: span 2;
	height: 28px;
	justify-content: center;
	width: 28px;
}

.hh-ct-help__quick svg {
	fill: none;
	height: 16px;
	stroke: currentColor;
	stroke-width: 1.9;
	width: 16px;
}

.hh-ct-help__quick span svg[fill="currentColor"] {
	fill: currentColor;
	stroke: none;
}

.hh-ct-help__quick strong {
	color: var(--hh-deep-2);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0;
	line-height: 1.25;
}

.hh-ct-help__quick small {
	color: var(--hh-muted);
	font-size: 12px;
	line-height: 1.38;
}

.hh-ct-help__sign {
	color: var(--hh-gold);
	font-family: var(--hh-script);
	font-size: 20px;
}

.hh-ct-card {
	background: rgba(255, 253, 248, 0.86);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	box-shadow: 0 12px 28px rgba(42, 55, 35, 0.08);
	display: flex;
	flex-direction: column;
	gap: 9px;
	min-height: 100%;
	padding: 24px 20px 18px;
}

.hh-ct-card__icon,
.hh-ct-exp__badge {
	align-items: center;
	background: var(--hh-deep-2);
	border-radius: 50%;
	box-shadow: 0 8px 16px rgba(22, 35, 27, 0.16);
	color: #fffdf8;
	display: flex;
	justify-content: center;
}

.hh-ct-card__icon {
	height: 52px;
	margin-bottom: 10px;
	width: 52px;
}

.hh-ct-card__icon svg,
.hh-ct-exp__badge svg {
	fill: none;
	height: 24px;
	stroke: #fffdf8;
	stroke-width: 1.8;
	width: 24px;
}

.hh-ct-card__icon svg[fill="currentColor"],
.hh-ct-cta__wa svg[fill="currentColor"] {
	fill: currentColor;
	stroke: none;
}

.hh-ct-card h3 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: 22px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.08;
	margin: 0;
}

.hh-ct-card__big {
	color: var(--hh-deep);
	font-size: 17px;
	font-weight: 500;
	margin: 0;
}

.hh-ct-card__big--email {
	font-size: 13px;
	overflow-wrap: anywhere;
}

.hh-ct-card p {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.52;
	margin: 0;
}

.hh-ct-card__btn {
	align-items: center;
	align-self: stretch;
	background: var(--hh-moss);
	border-radius: 6px;
	color: #fffdf8 !important;
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0;
	margin-top: auto;
	min-height: 34px;
	padding: 8px 14px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ct-card__btn:hover {
	background: var(--hh-gold);
}

.hh-ct-exp {
	padding: 6px 0 46px;
}

.hh-ct-section-heading {
	margin-bottom: 26px;
	max-width: 720px;
}

.hh-ct-exp__grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin-inline: auto;
	max-width: 1180px;
	padding: 0 32px;
}

.hh-ct-exp__card {
	background: rgba(255, 253, 248, 0.9);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	box-shadow: 0 12px 28px rgba(42, 55, 35, 0.08);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	text-align: center;
	text-decoration: none !important;
	transition: box-shadow 0.2s, transform 0.2s;
}

.hh-ct-exp__card:hover {
	box-shadow: 0 18px 34px rgba(42, 55, 35, 0.12);
	transform: translateY(-3px);
}

.hh-ct-exp__media {
	aspect-ratio: 16 / 8;
	display: block;
	overflow: hidden;
	position: relative;
}

.hh-ct-exp__badge {
	height: 52px;
	left: 18px;
	position: absolute;
	top: 12px;
	width: 52px;
}

.hh-ct-exp__card h3 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.08;
	margin: 14px 16px 6px;
}

.hh-ct-exp__card p {
	color: var(--hh-muted);
	font-size: 13.5px;
	line-height: 1.5;
	margin: 0 18px 12px;
}

.hh-ct-exp__link {
	color: var(--hh-moss);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0;
	margin: auto 16px 14px;
	text-transform: uppercase;
}

.hh-ct-mapfaq {
	background: var(--hh-warm-paper);
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	padding: 46px 0;
}

.hh-ct-mapfaq__inner {
	align-items: stretch;
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-inline: auto;
	max-width: 1040px;
	padding: 0 32px;
}

.hh-ct-panel {
	background: rgba(255, 253, 248, 0.9);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 8px;
	box-shadow: 0 12px 28px rgba(42, 55, 35, 0.08);
	padding: 20px;
}

.hh-ct-panel--faq {
	display: flex;
	flex-direction: column;
}

.hh-ct-panel h2 {
	font-size: 24px;
	margin-bottom: 14px;
}

.hh-ct-panel--map {
	display: grid;
	gap: 14px;
	grid-template-columns: 1fr;
}

.hh-ct-map {
	background: #dbe7c9;
	border-radius: 6px;
	box-shadow: inset 0 0 0 1px rgba(73, 111, 53, 0.1);
	min-height: 175px;
	overflow: hidden;
	position: relative;
}

.hh-ct-map iframe {
	border: 0;
	display: block;
	height: 100%;
	inset: 0;
	min-height: 175px;
	position: absolute;
	width: 100%;
}

.hh-ct-map__open {
	align-items: center;
	background: rgba(22, 49, 26, 0.94);
	border-radius: 6px;
	bottom: 12px;
	box-shadow: 0 8px 20px rgba(22, 35, 27, 0.2);
	color: #fffdf8 !important;
	display: inline-flex;
	font-size: 12px;
	font-weight: 700;
	gap: 7px;
	left: 12px;
	line-height: 1;
	padding: 10px 12px;
	position: absolute;
	text-decoration: none !important;
	z-index: 2;
}

.hh-ct-map__open:hover {
	background: var(--hh-gold);
	color: #fffdf8 !important;
}

.hh-ct-map__open svg {
	fill: none;
	height: 16px;
	stroke: currentColor;
	stroke-width: 1.8;
	width: 16px;
}

.hh-ct-map__open:focus-visible {
	outline: 3px solid rgba(201, 154, 69, 0.48);
	outline-offset: 2px;
}

.hh-ct-map noscript a {
	align-items: center;
	background: var(--hh-moss);
	color: #fffdf8;
	display: flex;
	justify-content: center;
	min-height: 220px;
	text-decoration: none;
}

.hh-ct-info {
	display: grid;
	gap: 12px;
	grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
}

.hh-ct-info__row {
	background: rgba(239, 243, 228, 0.5);
	border: 1px solid rgba(73, 111, 53, 0.1);
	border-radius: 6px;
	color: var(--hh-muted);
	display: flex;
	font-size: 13px;
	gap: 10px;
	line-height: 1.48;
	min-width: 0;
	padding: 12px;
}

.hh-ct-info__ic {
	color: var(--hh-moss);
	flex: 0 0 auto;
	height: 22px;
	width: 22px;
}

.hh-ct-info__ic svg {
	fill: none;
	height: 22px;
	stroke: currentColor;
	stroke-width: 1.7;
	width: 22px;
}

.hh-ct-info__row strong {
	color: var(--hh-deep-2);
	display: block;
	font-size: 13px;
	margin-bottom: 4px;
}

.hh-ct-info__row ul {
	display: grid;
	gap: 2px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.hh-ct-info__row li {
	display: flex;
	gap: 10px;
	justify-content: space-between;
}

.hh-ct-info__row li span {
	flex: 0 0 auto;
	text-align: right;
	white-space: nowrap;
}

.hh-ct-pickup {
	align-items: center;
	background: rgba(219, 231, 201, 0.56);
	border-radius: 6px;
	color: var(--hh-muted);
	display: flex;
	font-size: 13px;
	gap: 10px;
	line-height: 1.35;
	margin: 0;
	padding: 10px 12px;
}

.hh-ct-pickup span svg {
	fill: #496f35;
	height: auto;
	width: 34px;
}

.hh-ct-faq {
	display: grid;
}

.hh-ct-faq__item {
	border-bottom: 1px solid rgba(73, 111, 53, 0.14);
}

.hh-ct-faq__item summary {
	align-items: center;
	color: var(--hh-deep-2);
	cursor: pointer;
	display: flex;
	font-size: 13px;
	font-weight: 500;
	gap: 12px;
	justify-content: space-between;
	line-height: 1.3;
	list-style: none;
	padding: 9px 2px;
}

.hh-ct-faq__item summary::-webkit-details-marker {
	display: none;
}

.hh-ct-faq__chev {
	color: var(--hh-gold);
	transition: transform 0.2s;
}

.hh-ct-faq__item[open] .hh-ct-faq__chev {
	transform: rotate(180deg);
}

.hh-ct-faq__item p {
	color: var(--hh-muted);
	font-size: 13px;
	line-height: 1.55;
	margin: 0 2px 11px;
}

.hh-ct-faq__all {
	color: var(--hh-moss) !important;
	display: block;
	font-size: 13px;
	margin-top: auto;
	padding-top: 14px;
	text-align: center;
	text-decoration: none !important;
}

.hh-ct-reviews {
	padding: 46px 0 52px;
}

.hh-ct-reviews__wrap {
	margin-inline: auto;
	max-width: 1030px;
	padding: 0 62px;
	position: relative;
}

.hh-ct-reviews__grid {
	display: grid;
	grid-auto-columns: calc((100% - 36px) / 3);
	grid-auto-flow: column;
	gap: 18px;
	overflow-x: auto;
	overscroll-behavior-inline: contain;
	padding: 6px 2px 22px;
	scroll-behavior: smooth;
	scroll-snap-type: inline mandatory;
	scrollbar-width: none;
}

.hh-ct-reviews__grid::-webkit-scrollbar {
	display: none;
}

.hh-ct-review {
	align-items: flex-start;
	background: rgba(255, 253, 248, 0.86);
	border: 1px solid rgba(31, 78, 46, 0.1);
	border-radius: 8px;
	box-shadow: 0 12px 28px rgba(42, 55, 35, 0.08);
	display: grid;
	gap: 12px;
	grid-template-columns: 54px minmax(0, 1fr);
	margin: 0;
	min-height: 126px;
	padding: 16px;
	scroll-snap-align: start;
}

.hh-ct-review img {
	aspect-ratio: 1;
	border-radius: 50%;
	height: 54px;
	object-fit: cover;
	width: 54px;
}

.hh-ct-review__stars {
	color: #f4a51c;
	display: block;
	font-size: 14px;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 6px;
}

.hh-ct-review blockquote {
	color: var(--hh-ink);
	font-size: 13px;
	font-style: normal;
	line-height: 1.5;
	margin: 0 0 9px;
}

.hh-ct-review figcaption {
	color: var(--hh-muted);
	font-size: 12px;
	font-weight: 600;
}

.hh-ct-reviews__arrow {
	align-items: center;
	background: rgba(255, 253, 248, 0.94);
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 50%;
	box-shadow: 0 8px 18px rgba(22, 35, 27, 0.08);
	color: var(--hh-moss);
	display: flex;
	font-family: Georgia, serif;
	font-size: 28px;
	height: 34px;
	justify-content: center;
	padding: 0;
	position: absolute;
	top: 45%;
	transform: translateY(-50%);
	width: 34px;
	z-index: 2;
}

.hh-ct-reviews__arrow:hover:not(:disabled) {
	background: var(--hh-moss);
	color: #fffdf8;
}

.hh-ct-reviews__arrow:disabled {
	cursor: default;
	opacity: 0.28;
}

.hh-ct-reviews__arrow--prev {
	left: 18px;
}

.hh-ct-reviews__arrow--next {
	right: 18px;
}

.hh-ct-reviews__dots {
	display: flex;
	gap: 8px;
	justify-content: center;
	margin-top: 16px;
}

.hh-ct-reviews__dots button {
	appearance: none;
	background: rgba(31, 78, 46, 0.2);
	border: 0;
	border-radius: 50%;
	cursor: pointer;
	height: 8px;
	padding: 0;
	width: 8px;
}

.hh-ct-reviews__dots button:hover,
.hh-ct-reviews__dots .is-active {
	background: var(--hh-moss);
}

.hh-ct-cta {
	background:
		linear-gradient(90deg, rgba(19, 35, 18, 0.98), rgba(19, 35, 18, 0.92) 58%, rgba(19, 35, 18, 0.28)),
		var(--hh-deep);
	overflow: hidden;
	position: relative;
}

.hh-ct-cta__inner {
	align-items: center;
	display: flex;
	gap: 4px;
	margin-inline: auto;
	max-width: 1180px;
	min-height: 136px;
	padding: 28px 350px 28px 32px;
	position: relative;
}

.hh-ct-cta__copy {
	flex: 1 1 360px;
	min-width: 460px;
	position: relative;
	z-index: 1;
}

.hh-ct-cta__copy h2 {
	color: var(--hh-white);
	font-size: 27px;
	margin-bottom: 8px;
	white-space: nowrap;
}

.hh-ct-cta__copy p {
	color: #f2ddb1;
	font-family: var(--hh-script);
	font-size: 20px;
	line-height: 1.38;
	margin: 0;
}

.hh-ct-cta__actions {
	display: flex;
	flex: 0 0 auto;
	flex-wrap: nowrap;
	gap: 10px;
	position: relative;
	z-index: 1;
}

.hh-ct-cta__book,
.hh-ct-cta__wa {
	align-items: center;
	border-radius: 6px;
	display: inline-flex;
	font-size: 13px;
	font-weight: 800;
	gap: 8px;
	justify-content: center;
	letter-spacing: 0;
	min-height: 46px;
	padding: 12px 20px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-ct-cta__book {
	background: var(--hh-gold);
	color: var(--hh-white) !important;
}

.hh-ct-cta__book:hover {
	background: var(--hh-moss);
}

.hh-ct-cta__wa {
	background: transparent;
	border: 1px solid rgba(255, 253, 248, 0.72);
	color: var(--hh-white) !important;
}

.hh-ct-cta__wa:hover {
	background: rgba(255, 253, 248, 0.1);
}

.hh-ct-cta__wa svg {
	color: var(--hh-white);
	height: 19px;
	width: 19px;
}

.hh-ct-cta__image {
	bottom: -34px;
	height: 178px;
	margin: 0;
	opacity: 0.95;
	position: absolute;
	right: 10px;
	width: 330px;
}

.hh-ct-cta__image::before {
	background: linear-gradient(90deg, var(--hh-deep) 0%, rgba(19, 35, 18, 0.55) 38%, rgba(19, 35, 18, 0) 100%);
	content: "";
	inset: 0;
	position: absolute;
	z-index: 1;
}

.hh-ct-cta__image img {
	filter: saturate(1.08) contrast(1.02);
}

.hh-ct-benefits {
	background: var(--hh-paper);
	border-top: 1px solid rgba(31, 78, 46, 0.12);
	box-shadow: none;
}

.hh-ct-benefits .hh-ref-benefits__inner {
	grid-template-columns: repeat(9, minmax(0, 1fr));
	max-width: 1320px;
	padding: 16px 24px;
}

.hh-ct-benefits .hh-ref-benefit {
	gap: 5px;
	min-width: 0;
	padding: 5px 10px;
}

.hh-ct-benefits .hh-ref-benefit__icon {
	height: 28px;
	width: 28px;
}

.hh-ct-benefits .hh-ref-benefit strong {
	font-size: 11px;
	line-height: 1.25;
}

.hh-ct-benefits .hh-ref-benefit span:last-child:not(.hh-ref-benefit__icon) {
	display: none;
}

@media (max-width: 1180px) {
	.hh-ct-help__inner {
		grid-template-columns: 1fr;
		max-width: 900px;
	}

	.hh-ct-help__concierge {
		grid-template-columns: minmax(220px, 0.75fr) minmax(300px, 1.25fr);
	}

	.hh-ct-card {
		min-height: 250px;
	}

	.hh-ct-cta__inner {
		align-items: flex-start;
		flex-direction: column;
		gap: 16px;
		min-height: 190px;
		padding-right: 350px;
	}

	.hh-ct-cta__copy {
		flex: none;
		min-width: 0;
		width: 100%;
	}

	.hh-ct-cta__copy h2 {
		white-space: normal;
	}
}

@media (max-width: 980px) {
	.hh-ct-hero {
		min-height: 480px;
	}

	.hh-ct-hero__inner {
		padding-inline: 32px;
	}

	.hh-ct-hero__copy h1 {
		font-size: 48px;
	}

	.hh-ct-mapfaq__inner {
		grid-template-columns: 1fr;
		max-width: 650px;
	}

	.hh-ct-exp__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		max-width: 760px;
	}

	.hh-ct-reviews__grid {
		grid-auto-columns: calc((100% - 18px) / 2);
	}

	.hh-ct-panel--map {
		grid-template-columns: 1fr;
	}

	.hh-ct-reviews__wrap {
		max-width: 650px;
	}

	.hh-ct-cta__inner {
		align-items: flex-start;
		flex-direction: column;
	}

	.hh-ct-cta__image {
		opacity: 0.86;
		right: 10px;
	}

	.hh-ct-benefits .hh-ref-benefits__inner {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	.hh-ct-hero {
		background-position: 56% center;
		min-height: 500px;
	}

	.hh-ct-hero__shade {
		background: linear-gradient(180deg, rgba(13, 28, 12, 0.62), rgba(13, 28, 12, 0.88));
	}

	.hh-ct-hero__inner,
	.hh-ct-help__inner,
	.hh-ct-exp__grid,
	.hh-ct-mapfaq__inner,
	.hh-ct-reviews__wrap,
	.hh-ct-cta__inner {
		padding-inline: 20px;
	}

	.hh-ct-hero__copy h1 {
		font-size: 38px;
	}

	.hh-ct-hero__copy > p {
		font-size: 15px;
	}

	.hh-ct-help {
		padding-top: 28px;
	}

	.hh-ct-help__inner {
		grid-template-columns: 1fr;
	}

	.hh-ct-help__concierge,
	.hh-ct-help__channels {
		grid-template-columns: 1fr;
	}

	.hh-ct-help__photo {
		aspect-ratio: 4 / 3;
		max-height: 390px;
	}

	.hh-ct-exp__grid {
		grid-template-columns: 1fr;
	}

	.hh-ct-reviews__grid {
		grid-auto-columns: min(88%, 360px);
	}

	.hh-ct-reviews__arrow {
		display: none;
	}

	.hh-ct-help__intro h2,
	.hh-ct-exp > h2,
	.hh-ct-reviews > h2,
	.hh-ct-cta__copy h2 {
		font-size: 28px;
	}

	.hh-ct-card {
		min-height: auto;
	}

	.hh-ct-map {
		min-height: 190px;
	}

	.hh-ct-info {
		grid-template-columns: 1fr;
	}

	.hh-ct-review {
		grid-template-columns: 46px minmax(0, 1fr);
	}

	.hh-ct-review img {
		height: 46px;
		width: 46px;
	}

	.hh-ct-cta__actions,
	.hh-ct-cta__book,
	.hh-ct-cta__wa {
		width: 100%;
	}

	.hh-ct-cta__actions {
		flex-direction: column;
	}

	.hh-ct-cta__image {
		display: none;
	}

	.hh-ct-benefits .hh-ref-benefits__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		padding-inline: 14px;
	}
}

/* ============================================================
   BOOKING HUB (/booking/ page #325)
   ============================================================ */
.hh-bk-hero { min-height: 46vh; }
.hh-bk-hero .hh-ref-hero__lead { max-width: 640px; margin-top: 14px; color: #F3EFE2; font-size: 1.05rem; line-height: 1.6; }

.hh-bk-grid-section { background: #FBF6EC; padding: 64px 20px 80px; }
.hh-bk-grid {
	max-width: 1080px; margin: 0 auto;
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px;
}
.hh-bk-card {
	display: flex; flex-direction: column; background: #fff;
	border: 1px solid #E4E2D4; border-radius: 16px; overflow: hidden;
	box-shadow: 0 10px 30px rgba(32,53,29,.07); transition: transform .25s ease, box-shadow .25s ease;
}
.hh-bk-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(32,53,29,.14); }
.hh-bk-card__media {
	display: block; height: 210px; background-size: cover; background-position: center;
}
.hh-bk-card__body { display: flex; flex-direction: column; gap: 10px; padding: 24px 24px 26px; flex: 1; }
.hh-bk-card__meta {
	font-size: .76rem; letter-spacing: .08em; text-transform: uppercase;
	color: #C9973F; font-weight: 700;
}
.hh-bk-card__title { margin: 0; font-family: 'Cormorant Garamond', serif; font-size: 1.6rem; line-height: 1.2; color: #20351D; }
.hh-bk-card__title a { color: inherit; text-decoration: none; }
.hh-bk-card__title a:hover { color: #496F35; }
.hh-bk-card__blurb { margin: 0; color: #4A5343; font-size: .96rem; line-height: 1.55; }
.hh-bk-card__facts { list-style: none; margin: 4px 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 8px 16px; }
.hh-bk-card__facts li { position: relative; padding-left: 18px; font-size: .85rem; color: #46503C; }
.hh-bk-card__facts li::before { content: "\2713"; position: absolute; left: 0; color: #496F35; font-weight: 700; }
.hh-bk-card__foot {
	margin-top: auto; padding-top: 18px; display: flex; align-items: center; justify-content: space-between; gap: 12px;
	border-top: 1px solid #EEEADD;
}
.hh-bk-card__price { font-family: 'Cormorant Garamond', serif; font-size: 1.7rem; font-weight: 700; color: #20351D; line-height: 1; display: inline-flex; align-items: baseline; gap: 4px; }
.hh-bk-card__price span { font-size: .7rem; font-weight: 600; color: #8A8A7A; text-transform: uppercase; letter-spacing: .05em; }
.hh-bk-card__price small { font-size: .68rem; font-weight: 600; color: #8A8A7A; }
.hh-bk-card__btn {
	display: inline-block; background: #496F35; color: #fff; text-decoration: none;
	padding: 11px 20px; border-radius: 999px; font-weight: 700; font-size: .92rem;
	letter-spacing: .02em; transition: background .2s ease;
}
.hh-bk-card__btn:hover { background: #20351D; color: #fff; }

.hh-bk-enquiry { max-width: 1080px; margin: 44px auto 0; }
.hh-bk-enquiry__inner {
	background: #20351D; color: #F3EFE2; border-radius: 16px; padding: 34px 40px;
	display: flex; flex-direction: column; gap: 12px; align-items: flex-start;
}
.hh-bk-enquiry__inner h2 { margin: 0; font-family: 'Cormorant Garamond', serif; font-size: 1.55rem; color: #fff; }
.hh-bk-enquiry__inner p { margin: 0; color: #D8D6C5; line-height: 1.6; max-width: 720px; }
.hh-bk-enquiry__actions { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; margin-top: 6px; }
.hh-bk-enquiry__mail { color: #C9973F; text-decoration: none; font-weight: 600; }
.hh-bk-enquiry__mail:hover { text-decoration: underline; }

@media (max-width: 860px) {
	.hh-bk-grid { grid-template-columns: 1fr; gap: 24px; }
	.hh-bk-enquiry__inner { padding: 26px 24px; }
}

/* ============================================================
   SINGLE TRIP PAGE — booking-friendly redesign (P7)
   ============================================================ */
/* 1) Compact hero banner (was full-screen ~900px) */
.single-trip .wpte-gallery-wrapper__multi-banners{
	height:42vh; min-height:300px; max-height:440px;
	overflow:hidden; border-radius:0 0 20px 20px; position:relative;
}
.single-trip .wpte-gallery-wrapper__multi-banners .wpte-gallery-wrapper,
.single-trip .wpte-gallery-wrapper__multi-banners .banner-layout-default,
.single-trip .wpte-gallery-wrapper__multi-banners a{ height:100%; display:block; }
.single-trip .wpte-gallery-wrapper__multi-banners img{
	width:100%; height:100%; object-fit:cover; object-position:center 38%;
}
/* subtle gradient for depth */
.single-trip .wpte-gallery-wrapper__multi-banners::after{
	content:""; position:absolute; left:0; right:0; bottom:0; height:40%;
	background:linear-gradient(to top, rgba(20,30,18,.30), transparent); pointer-events:none;
}

/* 2) Content + sidebar rhythm */
.single-trip .content-area{ padding-top:8px; }
.single-trip .entry-title{ font-size:2.4rem; line-height:1.15; margin:0 0 6px; }
.single-trip #wte-trip-facts, .single-trip .wpte-trip-facts{ margin-bottom:24px; }

/* 3) Sticky booking card */
.single-trip .widget-area .wpte-booking-area-wrapper{ position:sticky; top:90px; }
.single-trip .wpte-booking-area.wpte-form-layout-1{
	border:1px solid #E4E2D4; border-radius:16px; padding:22px 22px 24px; background:#fff;
	box-shadow:0 14px 36px rgba(32,53,29,.10);
}
.single-trip .wpte-booking-area .wpte-price,
.single-trip .wpte-booking-area .wpte-trip-price{ font-family:'Cormorant Garamond',serif; }
.single-trip .wte-book-now, .single-trip .wpte-bf-btn{
	background:#496F35 !important; border-radius:999px !important; font-weight:700 !important;
	letter-spacing:.02em; transition:background .2s ease;
}
.single-trip .wte-book-now:hover, .single-trip .wpte-bf-btn:hover{ background:#20351D !important; }

/* 4) Enquiry form turned into a collapsible accordion */
.hh-enq-accordion{ margin:44px 0 0; border:1px solid #E4E2D4; border-radius:14px; overflow:hidden; background:#FBF6EC; }
.hh-enq-toggle{
	width:100%; display:flex; justify-content:space-between; align-items:center; gap:14px;
	padding:18px 22px; background:transparent; border:0; cursor:pointer; text-align:left;
	font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:600; color:#20351D;
}
.hh-enq-toggle:hover{ background:#F4EEDD; }
.hh-enq-caret{ font-size:1.6rem; line-height:1; color:#496F35; transition:transform .25s ease; flex:0 0 auto; }
.hh-enq-accordion.open .hh-enq-caret{ transform:rotate(45deg); }
.hh-enq-panel{ max-height:0; overflow:hidden; transition:max-height .4s ease; }
.hh-enq-accordion.open .hh-enq-panel{ max-height:4000px; }
.hh-enq-panel .wte_enquiry_contact_form-wrap{ padding:4px 22px 26px; }
.hh-enq-panel .enquiry-form-title{ display:none; }

@media (max-width:960px){
	.single-trip .widget-area .wpte-booking-area-wrapper{ position:static; }
	.single-trip .wpte-gallery-wrapper__multi-banners{ height:34vh; min-height:240px; }
	.single-trip .entry-title{ font-size:2rem; }
}

/* Hero fix: feat-img wrapper must fill the banner so the image covers (not clipped to top) */
.single-trip .wpte-gallery-wrapper__multi-banners .wpte-trip-feat-img{ height:100%; display:block; }
.single-trip .wpte-gallery-wrapper__multi-banners img{ object-position:center 45%; }

/* Booking sidebar — enrichment card (included list + WhatsApp + trust) */
.single-trip .hh-bk-extra{
	margin-top:16px; background:#fff; border:1px solid #E4E2D4; border-radius:16px;
	padding:18px 20px 16px; box-shadow:0 14px 36px rgba(32,53,29,.10);
}
.single-trip .hh-bk-more{ border-bottom:1px solid #eeeadd; margin:0 0 18px; padding:0 0 18px; }
.single-trip .hh-bk-more__eyebrow{ color:#c9973f; font-size:14px; font-weight:700; letter-spacing:.08em; margin:0 0 4px; text-transform:uppercase; }
.single-trip .hh-bk-more__h{ color:#20351d; font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:700; line-height:1.15; margin:0 0 11px; }
.single-trip .hh-bk-more ul{ display:grid; gap:7px; list-style:none; margin:0; padding:0; }
.single-trip .hh-bk-more a{ align-items:center; background:#fbf6ec; border-radius:8px; color:#30552f; display:flex; font-size:14px; font-weight:700; gap:10px; justify-content:space-between; line-height:1.35; padding:10px 12px; text-decoration:none; }
.single-trip .hh-bk-more a:hover{ background:#edf3e9; color:#20351d; }
.single-trip .hh-bk-more a span{ color:#c9973f; font-size:18px; }
.single-trip .hh-bk-extra__h{
	margin:0 0 12px; font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:700; color:#20351D;
}
.single-trip .hh-bk-incl{ list-style:none; margin:0 0 14px; padding:0; display:grid; gap:8px; }
.single-trip .hh-bk-incl li{ position:relative; padding-left:24px; font-size:16px; color:#46503C; line-height:1.5; }
.single-trip .hh-bk-incl li::before{ content:"\2713"; position:absolute; left:0; color:#496F35; font-weight:700; }
.single-trip .hh-bk-wa{
	display:block; text-align:center; background:#496F35; color:#fff; text-decoration:none;
	font-size:16px; font-weight:700; padding:13px; border-radius:999px; margin-bottom:10px; transition:background .2s ease;
}
.single-trip .hh-bk-wa:hover{ background:#20351D; color:#fff; }
.single-trip .hh-bk-trust{ margin:0; text-align:center; font-size:14px; color:#9A8C66; letter-spacing:.02em; }

/* Farm Updates: Home-aligned farm journal */
body.happy-herb-redesign.hh-ref-farm-updates-page #site-header {
	background: linear-gradient(180deg, rgba(13, 28, 12, 0.88), rgba(13, 28, 12, 0.28)) !important;
	border-bottom: 0;
	box-shadow: none;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 30;
}

body.admin-bar.happy-herb-redesign.hh-ref-farm-updates-page #site-header {
	top: 32px;
}

.hh-farm-page {
	background: var(--hh-paper);
	color: var(--hh-ink);
	font-family: var(--hh-sans);
	letter-spacing: 0;
	overflow: hidden;
}

.hh-farm-hero::before {
	background-position: 62% center;
}

.hh-farm-hero .hh-ref-hero__shade {
	background:
		linear-gradient(90deg, rgba(10, 25, 12, 0.94) 0%, rgba(10, 25, 12, 0.76) 36%, rgba(10, 25, 12, 0.28) 67%, rgba(10, 25, 12, 0.08) 100%),
		linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.08) 50%, rgba(0, 0, 0, 0.62));
}

.hh-farm-hero .hh-ref-hero__copy {
	max-width: 650px;
}

.hh-farm-hero .hh-ref-hero__script {
	align-items: center;
	display: flex;
	gap: 12px;
	margin: 0 0 8px;
}

.hh-farm-live-badge {
	background: #d92323;
	border: 1px solid rgba(255, 255, 255, 0.48);
	border-radius: 6px;
	box-shadow: 0 4px 14px rgba(125, 0, 0, 0.34);
	color: #fff;
	display: inline-flex;
	font-family: var(--hh-sans);
	font-size: clamp(13px, 1.2vw, 16px);
	font-weight: 800;
	letter-spacing: 0.12em;
	line-height: 1;
	padding: 8px 12px 7px;
	text-shadow: none;
	text-transform: uppercase;
}

.hh-farm-hero .hh-ref-hero__title {
	max-width: 610px;
}

.hh-farm-hero .hh-ref-hero__text {
	max-width: 530px;
}

.hh-farm-benefits .hh-ref-benefits__inner {
	grid-template-columns: repeat(6, minmax(0, 1fr));
	max-width: 1180px;
}

.hh-farm-trust {
	border-top: 1px solid rgba(31, 78, 46, 0.1);
}

.hh-farm-week,
.hh-farm-calendar,
.hh-farm-journal {
	margin-inline: auto;
	max-width: 1180px;
	padding: 68px 32px;
}

.hh-farm-heading {
	margin: 0 auto 34px;
	max-width: 720px;
	text-align: center;
}

.hh-farm-heading > span,
.hh-farm-week__eyebrow {
	color: var(--hh-gold);
	display: block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: 9px;
	text-transform: uppercase;
}

.hh-farm-heading h2,
.hh-farm-week__note h3,
.hh-farm-cta__copy h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-weight: 600;
	letter-spacing: 0;
}

.hh-farm-heading h2 {
	font-size: clamp(36px, 4vw, 50px);
	line-height: 1;
	margin: 0 0 12px;
}

.hh-farm-heading p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.65;
	margin: 0;
}

.hh-farm-week__layout {
	align-items: stretch;
	display: grid;
	gap: 34px;
	grid-template-columns: minmax(0, 1.52fr) minmax(280px, 0.68fr);
}

.hh-farm-week__mosaic {
	display: grid;
	gap: 8px;
	grid-template-columns: minmax(0, 1.55fr) minmax(160px, 0.72fr);
	grid-template-rows: repeat(3, minmax(0, 1fr));
	height: 470px;
}

.hh-farm-week__photo {
	border-radius: 6px;
	margin: 0;
	min-height: 0;
	overflow: hidden;
}

.hh-farm-week__photo--feature {
	grid-row: 1 / 4;
}

.hh-farm-week__photo img,
.hh-farm-cta__image img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.hh-farm-week__photo--feature img {
	object-position: center 44%;
}

.hh-farm-week__note {
	align-self: center;
	border-left: 1px solid rgba(31, 78, 46, 0.18);
	padding: 12px 0 12px 32px;
}

.hh-farm-week__note h3 {
	font-size: 32px;
	line-height: 1.02;
	margin: 0 0 16px;
}

.hh-farm-week__note > p {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.68;
	margin: 0 0 22px;
}

.hh-farm-week__note ul {
	display: grid;
	gap: 12px;
	list-style: none;
	margin: 0 0 24px;
	padding: 0;
}

.hh-farm-week__note li {
	display: grid;
	gap: 2px 11px;
	grid-template-columns: 34px minmax(0, 1fr);
}

.hh-farm-week__note li > span {
	align-items: center;
	background: rgba(73, 111, 53, 0.1);
	border-radius: 50%;
	color: var(--hh-moss);
	display: flex;
	grid-row: span 2;
	height: 34px;
	justify-content: center;
	width: 34px;
}

.hh-farm-week__note li svg {
	fill: none;
	height: 19px;
	stroke: currentColor;
	stroke-width: 1.8;
	width: 19px;
}

.hh-farm-week__note li strong {
	color: var(--hh-deep-2);
	font-size: 13px;
	line-height: 1.3;
}

.hh-farm-week__note li small {
	color: var(--hh-muted);
	font-size: 12px;
	line-height: 1.35;
}

.hh-farm-week__note > a,
.hh-ref-blog-card__link {
	color: var(--hh-moss) !important;
	font-size: 12px;
	font-weight: 800;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-farm-calendar {
	background: rgba(239, 243, 228, 0.56);
	border: 1px solid rgba(31, 78, 46, 0.08);
	max-width: none;
	padding-bottom: 58px;
	padding-top: 58px;
}

.hh-farm-calendar > * {
	margin-inline: auto;
	max-width: 1116px;
}

.hh-farm-calendar__grid {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
}

.hh-farm-calendar__item {
	align-items: center;
	border-right: 1px solid rgba(31, 78, 46, 0.15);
	display: flex;
	flex-direction: column;
	min-height: 150px;
	padding: 18px 16px;
	text-align: center;
}

.hh-farm-calendar__item:last-child {
	border-right: 0;
}

.hh-farm-calendar__icon {
	color: var(--hh-moss);
	display: flex;
	height: 38px;
	margin-bottom: 12px;
	width: 38px;
}

.hh-farm-calendar__icon svg {
	fill: none;
	height: 100%;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.7;
	width: 100%;
}

.hh-farm-calendar__item strong {
	color: var(--hh-deep-2);
	font-size: 13px;
	text-transform: uppercase;
}

.hh-farm-calendar__item p {
	color: var(--hh-muted);
	font-size: 12px;
	line-height: 1.45;
	margin: 7px 0 0;
}

.hh-farm-journal__grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.hh-farm-journal .hh-ref-blog-card {
	border-radius: 6px;
	box-shadow: 0 12px 28px rgba(42, 55, 35, 0.08);
}

.hh-farm-journal .hh-ref-blog-card__image {
	aspect-ratio: 4 / 3;
}

.hh-farm-journal .hh-ref-blog-card__body {
	gap: 9px;
	padding: 17px;
}

.hh-farm-journal .hh-ref-blog-card h3 {
	font-size: 23px;
	line-height: 1.05;
}

.hh-farm-journal .hh-ref-blog-card p {
	font-size: 13px;
	line-height: 1.55;
}

.hh-farm-faq {
	background:
		radial-gradient(circle at 92% 12%, rgba(201, 154, 69, 0.09), transparent 30%),
		#fbf6ec;
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(54px, 6vw, 76px) 32px;
}

.hh-farm-faq__inner {
	margin: 0 auto;
	max-width: 1180px;
}

.hh-farm-faq__heading {
	margin: 0 0 28px;
}

.hh-farm-faq__heading > span {
	color: var(--hh-gold);
	display: block;
	font-family: var(--hh-script);
	font-size: 34px;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: 7px;
	text-transform: none;
}

.hh-farm-faq__heading h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(32px, 3.6vw, 44px);
	font-weight: 600;
	letter-spacing: -0.015em;
	line-height: 1.02;
	margin: 0;
}

.hh-farm-faq__grid {
	display: grid;
	gap: 18px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hh-farm-faq__column {
	align-content: start;
	display: grid;
	gap: 11px;
}

.hh-farm-faq__item {
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(31, 78, 46, 0.11);
	border-radius: 6px;
	box-shadow: 0 5px 18px rgba(42, 55, 35, 0.035);
	overflow: hidden;
}

.hh-farm-faq__item summary {
	align-items: center;
	color: var(--hh-deep-2);
	cursor: pointer;
	display: flex;
	font-size: 14px;
	font-weight: 700;
	gap: 18px;
	justify-content: space-between;
	line-height: 1.4;
	list-style: none;
	padding: 16px 18px;
}

.hh-farm-faq__item summary::-webkit-details-marker {
	display: none;
}

.hh-farm-faq__plus {
	flex: 0 0 auto;
	height: 16px;
	position: relative;
	width: 16px;
}

.hh-farm-faq__plus::before,
.hh-farm-faq__plus::after {
	background: var(--hh-moss);
	content: "";
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.hh-farm-faq__plus::before {
	height: 2px;
	width: 14px;
}

.hh-farm-faq__plus::after {
	height: 14px;
	width: 2px;
}

.hh-farm-faq__item[open] .hh-farm-faq__plus::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg);
}

.hh-farm-faq__item p {
	border-top: 1px solid rgba(31, 78, 46, 0.08);
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.65;
	margin: 0;
	padding: 14px 18px 17px;
}

.hh-farm-cta {
	align-items: center;
	background:
		linear-gradient(90deg, rgba(19, 35, 18, 0.98), rgba(19, 35, 18, 0.95)),
		var(--hh-deep);
	color: var(--hh-white);
	display: grid;
	grid-template-columns: minmax(240px, 0.72fr) minmax(320px, 1fr) auto;
	min-height: 190px;
	overflow: hidden;
}

.hh-farm-cta__image {
	align-self: stretch;
	height: 190px;
	margin: 0;
	min-height: 0;
	position: relative;
}

.hh-farm-cta__image::after {
	background: linear-gradient(90deg, transparent 58%, var(--hh-deep));
	content: "";
	inset: 0;
	position: absolute;
}

.hh-farm-cta__copy {
	padding: 30px 34px;
}

.hh-farm-cta__copy h2 {
	color: var(--hh-white);
	font-size: 32px;
	line-height: 1;
	margin: 0 0 10px;
}

.hh-farm-cta__copy p {
	color: rgba(255, 253, 248, 0.82);
	font-size: 14px;
	line-height: 1.55;
	margin: 0;
	max-width: 480px;
}

.hh-farm-cta__actions {
	display: grid;
	gap: 10px;
	padding: 28px 36px 28px 0;
}

.hh-farm-cta__actions a {
	align-items: center;
	border-radius: 6px;
	display: inline-flex;
	font-size: 12px;
	font-weight: 800;
	gap: 8px;
	justify-content: center;
	min-height: 44px;
	min-width: 210px;
	padding: 10px 20px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-farm-cta__book {
	background: var(--hh-gold);
	color: var(--hh-white) !important;
}

.hh-farm-cta__wa {
	border: 1px solid rgba(255, 253, 248, 0.78);
	color: var(--hh-white) !important;
}

.hh-farm-cta__wa svg {
	fill: currentColor;
	height: 18px;
	width: 18px;
}

@media (max-width: 980px) {
	.hh-farm-benefits .hh-ref-benefits__inner {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.hh-farm-week__layout {
		grid-template-columns: 1fr;
	}

	.hh-farm-week__mosaic {
		height: 540px;
	}

	.hh-farm-week__note {
		border-left: 0;
		border-top: 1px solid rgba(31, 78, 46, 0.18);
		padding: 28px 0 0;
	}

	.hh-farm-calendar__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.hh-farm-calendar__item:nth-child(3) {
		border-right: 0;
	}

	.hh-farm-calendar__item:nth-child(-n+3) {
		border-bottom: 1px solid rgba(31, 78, 46, 0.15);
	}

	.hh-farm-journal__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-farm-cta {
		grid-template-columns: minmax(220px, 0.7fr) minmax(0, 1fr);
	}

	.hh-farm-cta__actions {
		grid-column: 2;
		padding: 0 30px 28px;
	}

	.hh-farm-cta__image {
		grid-row: 1 / 3;
		height: 100%;
		min-height: 240px;
	}
}

@media (max-width: 767px) {
	body.happy-herb-redesign.hh-ref-farm-updates-page #site-header,
	body.admin-bar.happy-herb-redesign.hh-ref-farm-updates-page #site-header {
		background: rgba(19, 35, 18, 0.98) !important;
		position: relative;
		top: auto;
	}

	.hh-farm-hero,
	.hh-farm-hero .hh-ref-hero__inner {
		min-height: var(--hh-ref-hero-height);
	}

	.hh-farm-hero::before {
		background-position: 72% center;
	}

	.hh-farm-hero .hh-ref-hero__inner {
		padding-top: 76px;
		padding-bottom: 24px;
	}

	.hh-farm-hero .hh-ref-hero__shade {
		background: linear-gradient(180deg, rgba(12, 28, 13, 0.52), rgba(12, 28, 13, 0.9));
	}

	.hh-farm-hero .hh-ref-hero__proof {
		display: grid;
		gap: 0;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-farm-hero .hh-ref-hero__proof-item {
		border-bottom: 1px solid rgba(255, 255, 255, 0.2);
		min-width: 0;
		padding: 12px 8px;
		width: auto;
	}

	.hh-farm-hero .hh-ref-hero__proof-item:nth-child(odd) {
		border-right: 1px solid rgba(255, 255, 255, 0.2);
	}

	.hh-farm-hero .hh-ref-hero__proof-copy {
		white-space: normal;
	}

	.hh-farm-benefits .hh-ref-benefits__inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-farm-week,
	.hh-farm-journal {
		padding: 48px 20px;
	}

	.hh-farm-heading {
		margin-bottom: 26px;
	}

	.hh-farm-week__mosaic {
		height: auto;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-template-rows: 230px 130px 130px;
		min-height: 0;
	}

	.hh-farm-week__photo--feature {
		grid-column: 1 / -1;
		grid-row: auto;
	}

	.hh-farm-week__photo:last-child {
		grid-column: 1 / -1;
	}

	.hh-farm-calendar {
		padding: 46px 20px;
	}

	.hh-farm-calendar__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-farm-calendar__item,
	.hh-farm-calendar__item:nth-child(3) {
		border-bottom: 1px solid rgba(31, 78, 46, 0.15);
		border-right: 1px solid rgba(31, 78, 46, 0.15);
	}

	.hh-farm-calendar__item:nth-child(even) {
		border-right: 0;
	}

	.hh-farm-calendar__item:nth-last-child(-n+2) {
		border-bottom: 0;
	}

	.hh-farm-journal__grid {
		grid-template-columns: 1fr;
	}

	.hh-farm-faq {
		padding: 48px 20px;
	}

	.hh-farm-faq__grid {
		grid-template-columns: 1fr;
	}

	.hh-farm-cta {
		grid-template-columns: 1fr;
	}

	.hh-farm-cta__image {
		aspect-ratio: 16 / 8;
		height: auto;
		min-height: 0;
	}

	.hh-farm-cta__image::after {
		background: linear-gradient(180deg, transparent 50%, var(--hh-deep));
	}

	.hh-farm-cta__copy {
		padding: 22px 20px 16px;
	}

	.hh-farm-cta__actions {
		grid-column: auto;
		padding: 0 20px 26px;
	}

	.hh-farm-cta__actions a {
		width: 100%;
	}
}

/* Single farm journal post */
body.happy-herb-redesign.single-post #site-header {
	background: linear-gradient(180deg, rgba(13, 28, 12, 0.92), rgba(13, 28, 12, 0.34)) !important;
	border-bottom: 0;
	box-shadow: none;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 30;
}

body.admin-bar.happy-herb-redesign.single-post #site-header {
	top: 32px;
}

body.happy-herb-redesign.single-post .comments-area {
	display: none !important;
}

.hh-single-post {
	background: var(--hh-paper);
	color: var(--hh-ink);
	font-family: var(--hh-sans);
	overflow: hidden;
}

.hh-single-post__hero {
	align-items: flex-end;
	background-image: var(--hh-post-hero);
	background-position: center;
	background-size: cover;
	display: flex;
	min-height: 610px;
	position: relative;
}

.hh-single-post__hero-shade {
	background:
		linear-gradient(90deg, rgba(10, 25, 12, 0.92) 0%, rgba(10, 25, 12, 0.69) 43%, rgba(10, 25, 12, 0.2) 76%),
		linear-gradient(180deg, rgba(10, 25, 12, 0.1) 30%, rgba(10, 25, 12, 0.86) 100%);
	inset: 0;
	position: absolute;
}

.hh-single-post__hero-inner {
	color: var(--hh-white);
	margin: 0 auto;
	max-width: 1180px;
	padding: 190px 32px 72px;
	position: relative;
	width: 100%;
	z-index: 1;
}

.hh-single-post__back {
	color: rgba(255, 255, 255, 0.86) !important;
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.04em;
	margin-bottom: 40px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-single-post__back:hover {
	color: var(--hh-gold) !important;
}

.hh-single-post__eyebrow {
	color: var(--hh-gold);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.13em;
	margin: 0 0 12px;
	text-transform: uppercase;
}

.hh-single-post__hero h1 {
	color: var(--hh-white);
	font-family: var(--hh-serif);
	font-size: clamp(42px, 4.7vw, 64px);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.02;
	margin: 0;
	max-width: 820px;
	text-wrap: balance;
}

.hh-single-post__meta {
	align-items: center;
	color: rgba(255, 255, 255, 0.78);
	display: flex;
	flex-wrap: wrap;
	font-size: 13px;
	font-weight: 600;
	gap: 10px;
	margin-top: 24px;
}

.hh-single-post__shell {
	margin: 0 auto;
	max-width: 920px;
	padding: 72px 32px 82px;
}

.hh-single-post__content {
	color: #354238;
	font-family: var(--hh-sans);
	font-size: 18px;
	line-height: 1.82;
	margin: 0 auto;
	max-width: 760px;
}

.hh-single-post__content > :first-child {
	margin-top: 0;
}

.hh-single-post__content > :last-child {
	margin-bottom: 0;
}

.hh-single-post__content .hh-article-lead {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(23px, 2.6vw, 29px);
	font-weight: 500;
	line-height: 1.42;
	margin-bottom: 1.35em;
}

.hh-single-post__content p,
.hh-single-post__content ul,
.hh-single-post__content ol {
	margin-bottom: 1.45em;
}

.hh-single-post__content h2,
.hh-single-post__content h3,
.hh-single-post__content h4 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-weight: 600;
	letter-spacing: 0;
}

.hh-single-post__content h2 {
	font-size: clamp(34px, 4vw, 46px);
	line-height: 1.05;
	margin: 1.45em 0 0.45em;
}

.hh-single-post__content h3 {
	font-size: clamp(28px, 3vw, 35px);
	line-height: 1.1;
	margin: 1.35em 0 0.45em;
}

.hh-single-post__content h4 {
	font-size: 24px;
	line-height: 1.2;
	margin: 1.3em 0 0.45em;
}

.hh-single-post__content a {
	font-weight: 700;
}

.hh-single-post__content img {
	display: block;
	height: auto;
	margin: 38px auto;
	max-width: 100%;
}

.hh-single-post__content figure {
	margin: 42px 0;
}

.hh-single-post__content figcaption {
	color: var(--hh-muted);
	font-size: 13px;
	line-height: 1.5;
	margin-top: 10px;
	text-align: center;
}

.hh-single-post__content blockquote {
	border-left: 3px solid var(--hh-gold);
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: 28px;
	font-style: normal;
	line-height: 1.25;
	margin: 42px 0;
	padding: 8px 0 8px 28px;
}

.hh-single-post__content blockquote p:last-child {
	margin-bottom: 0;
}

.hh-single-post__content .hh-article-status {
	background: #f1f4e8;
	border: 1px solid rgba(73, 111, 53, 0.18);
	border-left: 4px solid var(--hh-moss);
	border-radius: 4px;
	margin: 42px 0;
	padding: 24px 28px 25px;
}

.hh-single-post__content .hh-article-status__eyebrow {
	color: var(--hh-clay);
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.12em;
	margin: 0 0 7px;
	text-transform: uppercase;
}

.hh-single-post__content .hh-article-status h3 {
	font-size: clamp(27px, 3vw, 34px);
	margin: 0 0 10px;
}

.hh-single-post__content .hh-article-status p:last-child {
	margin-bottom: 0;
}

.hh-single-post__content li {
	margin-bottom: 0.45em;
	padding-left: 0.25em;
}

.hh-single-post__content table {
	border-collapse: collapse;
	font-size: 15px;
	margin: 38px 0;
	width: 100%;
}

.hh-single-post__content th,
.hh-single-post__content td {
	border: 1px solid var(--hh-line);
	padding: 12px 14px;
	text-align: left;
}

.hh-single-post__content th {
	background: var(--hh-soft);
	color: var(--hh-deep-2);
}

.hh-single-post__content .wp-block-button__link {
	background: var(--hh-forest);
	border-radius: 6px;
	color: var(--hh-white) !important;
	font-size: 13px;
	font-weight: 800;
	padding: 13px 22px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-single-post__navigation {
	border-top: 1px solid rgba(31, 78, 46, 0.16);
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 68px;
	padding-top: 30px;
}

.hh-single-post__nav-link {
	display: flex;
	flex-direction: column;
	gap: 6px;
	text-decoration: none !important;
}

.hh-single-post__nav-link--next {
	text-align: right;
}

.hh-single-post__nav-link span {
	color: var(--hh-gold);
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.hh-single-post__nav-link strong {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: 23px;
	font-weight: 600;
	line-height: 1.08;
}

.hh-single-post__nav-link:hover strong {
	color: var(--hh-clay);
}

.hh-single-post__related {
	background: rgba(239, 243, 228, 0.56);
	border-top: 1px solid rgba(31, 78, 46, 0.08);
	padding: 68px 32px 76px;
}

.hh-single-post__related > * {
	margin-inline: auto;
	max-width: 1116px;
}

.hh-single-post__related-grid {
	display: grid;
	gap: 22px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hh-single-post__related .hh-ref-blog-card {
	border-radius: 6px;
	box-shadow: 0 12px 28px rgba(42, 55, 35, 0.08);
}

.hh-single-post__related .hh-ref-blog-card__image {
	aspect-ratio: 4 / 3;
}

@media (max-width: 900px) {
	.hh-single-post__related-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	body.happy-herb-redesign.single-post #site-header,
	body.admin-bar.happy-herb-redesign.single-post #site-header {
		background: rgba(19, 35, 18, 0.98) !important;
		position: relative;
		top: auto;
	}

	.hh-single-post__hero {
		min-height: 520px;
	}

	.hh-single-post__hero-shade {
		background: linear-gradient(180deg, rgba(10, 25, 12, 0.34), rgba(10, 25, 12, 0.9));
	}

	.hh-single-post__hero-inner {
		padding: 90px 20px 44px;
	}

	.hh-single-post__back {
		margin-bottom: 70px;
	}

	.hh-single-post__hero h1 {
		font-size: clamp(36px, 10vw, 48px);
	}

	.hh-single-post__shell {
		padding: 48px 20px 58px;
	}

	.hh-single-post__content {
		font-size: 17px;
		line-height: 1.72;
	}

	.hh-single-post__content blockquote {
		font-size: 24px;
		padding-left: 20px;
	}

	.hh-single-post__navigation,
	.hh-single-post__related-grid {
		grid-template-columns: 1fr;
	}

	.hh-single-post__nav-link--next {
		border-top: 1px solid rgba(31, 78, 46, 0.12);
		padding-top: 22px;
		text-align: left;
	}

	.hh-single-post__related {
		padding: 50px 20px 58px;
	}
}
/* ==========================================================================
   Our Story
   ========================================================================== */

body.hh-our-story-page {
  background: var(--hh-paper, #fffdf8);
}

body.happy-herb-redesign.hh-ref-header-dark.hh-our-story-page #site-header {
  position: absolute;
  inset: 0 0 auto;
  z-index: 30;
  background: linear-gradient(180deg, rgba(10, 37, 20, 0.96), rgba(10, 37, 20, 0.78) 72%, transparent);
  border: 0;
  box-shadow: none;
}

body.admin-bar.happy-herb-redesign.hh-ref-header-dark.hh-our-story-page #site-header {
  top: 32px;
}

body.hh-our-story-page .page-header {
  display: none;
}

body.hh-our-story-page #content-wrap,
body.hh-our-story-page #primary,
body.hh-our-story-page #content,
body.hh-our-story-page #post-24,
body.hh-our-story-page .entry-content {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

body.hh-our-story-page .elementor-24 .elementor-element-79616ec {
  --padding-top: 0;
  --padding-right: 0;
  --padding-bottom: 0;
  --padding-left: 0;
  padding: 0 !important;
  background: transparent !important;
}

body.hh-our-story-page .elementor-24 .elementor-element-7621250,
body.hh-our-story-page .elementor-24 .elementor-widget-html,
body.hh-our-story-page .elementor-24 .elementor-widget-container {
  width: 100%;
  max-width: none;
}

.hh-story-page {
  overflow: hidden;
  font-family: var(--hh-sans);
  font-size: 17px;
  line-height: 1.65;
  color: var(--hh-ink, #243126);
  background: var(--hh-paper, #fffdf8);
}

.hh-story-page h1,
.hh-story-page h2,
.hh-story-page h3 {
  font-family: var(--hh-serif);
}

.hh-story-page h1,
.hh-story-page h2,
.hh-story-page h3,
.hh-story-page p {
  margin-top: 0;
}

.hh-story-hero {
  min-height: var(--hh-ref-hero-height);
}

.hh-story-hero::before {
  background-position: center 42%;
}

.hh-story-hero .hh-ref-hero__shade {
  background:
    linear-gradient(90deg, rgba(8, 27, 15, 0.9) 0%, rgba(8, 27, 15, 0.7) 43%, rgba(8, 27, 15, 0.18) 70%, rgba(8, 27, 15, 0.08) 100%),
    linear-gradient(0deg, rgba(8, 27, 15, 0.3), transparent 45%);
}

.hh-story-hero .hh-ref-hero__inner {
  padding-top: 120px;
}

.hh-story-hero .hh-ref-hero__copy {
  max-width: 680px;
}

.hh-story-hero .hh-ref-hero__script {
  color: var(--hh-gold, #d6a447);
}

.hh-story-hero h1 {
  max-width: 650px;
  font-size: clamp(3.15rem, 5.5vw, 5.55rem);
  line-height: 0.98;
}

.hh-story-hero .hh-ref-hero__text {
  max-width: 590px;
  font-family: var(--hh-sans);
  font-size: clamp(16px, 1.35vw, 18px);
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.93);
}

.hh-story-benefits,
.hh-story-trust {
  position: relative;
  z-index: 5;
}

.hh-story-founder,
.hh-story-journey,
.hh-story-beliefs,
.hh-story-love {
  padding: clamp(68px, 8vw, 112px) 24px;
}

.hh-story-founder {
  background:
    radial-gradient(circle at 88% 14%, rgba(151, 166, 106, 0.13), transparent 26%),
    var(--hh-paper, #fffdf8);
}

.hh-story-founder__inner {
  display: grid;
  grid-template-columns: minmax(270px, 0.72fr) minmax(520px, 1.28fr);
  gap: clamp(42px, 6vw, 82px);
  align-items: center;
  width: min(1180px, 100%);
  margin: 0 auto;
}

.hh-story-kicker {
  display: block;
  margin-bottom: 12px;
  font-family: var(--hh-script);
  font-size: clamp(1.35rem, 2vw, 1.85rem);
  line-height: 1.1;
  color: var(--hh-gold, #bd8933);
}

.hh-story-founder__copy h2,
.hh-story-heading h2,
.hh-story-video__copy h2,
.hh-story-cta h2 {
  font-family: var(--hh-serif);
  font-weight: 600;
  letter-spacing: -0.025em;
}

.hh-story-founder__copy h2 {
  margin-bottom: 22px;
  font-size: clamp(38px, 4.8vw, 60px);
  line-height: 1.02;
  color: var(--hh-deep, #173c24);
}

.hh-story-founder__copy p {
  margin-bottom: 16px;
  font-size: 1.1rem;
  line-height: 1.75;
  color: #4e594e;
}

.hh-story-text-link {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-top: 12px;
  padding-bottom: 5px;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--hh-deep, #173c24);
  border-bottom: 1px solid var(--hh-gold, #bd8933);
}

.hh-story-text-link:hover {
  gap: 13px;
  color: var(--hh-gold, #bd8933);
}

.hh-story-founder__gallery {
  position: relative;
  display: grid;
  grid-template-columns: 1.65fr 0.9fr;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 14px;
  min-height: 520px;
}

.hh-story-founder__gallery::before {
  position: absolute;
  right: -34px;
  bottom: -42px;
  width: 150px;
  height: 190px;
  content: "";
  opacity: 0.32;
  background: radial-gradient(ellipse at center, transparent 45%, #77924f 47%, transparent 50%);
  transform: rotate(-18deg);
  pointer-events: none;
}

.hh-story-founder__gallery figure {
  position: relative;
  z-index: 1;
  overflow: hidden;
  margin: 0;
  border: 1px solid rgba(38, 67, 38, 0.12);
  border-radius: 8px;
  background: #e8eadc;
  box-shadow: 0 14px 34px rgba(34, 50, 31, 0.13);
}

.hh-story-founder__gallery .hh-story-founder__main {
  grid-row: 1 / span 2;
}

.hh-story-founder__gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms ease;
}

.hh-story-founder__gallery figure:hover img {
  transform: scale(1.025);
}

.hh-story-journey {
  background: var(--hh-warm-paper, #f9f4e9);
}

.hh-story-heading {
  display: flex;
  flex-direction: column;
  width: min(760px, 100%);
  margin: 0 auto clamp(48px, 6vw, 72px);
  text-align: center;
}

.hh-story-heading h2 {
  order: 1;
  margin-bottom: 8px;
  font-size: clamp(36px, 3.8vw, 54px);
  line-height: 1.05;
  color: var(--hh-deep, #173c24);
}

.hh-story-heading > span {
  order: 2;
  display: block;
  margin: 12px 0 0;
  font-family: var(--hh-script);
  font-size: clamp(1.25rem, 1.9vw, 1.7rem);
  color: var(--hh-gold, #bd8933);
}

.hh-story-timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  width: min(1180px, 100%);
  margin: 0 auto;
}

.hh-story-timeline::before {
  position: absolute;
  top: 0;
  right: 10%;
  left: 10%;
  z-index: 0;
  height: 1px;
  content: "";
  background: linear-gradient(90deg, transparent, rgba(169, 131, 56, 0.52) 12%, rgba(169, 131, 56, 0.52) 88%, transparent);
}

.hh-story-timeline__card {
  position: relative;
  z-index: 1;
  min-height: 340px;
  padding: 66px 26px 30px;
  border: 1px solid rgba(53, 72, 47, 0.1);
  border-radius: 7px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 12px 30px rgba(46, 55, 37, 0.08);
}

.hh-story-timeline__icon {
  position: absolute;
  top: 0;
  left: 50%;
  display: grid;
  width: 64px;
  height: 64px;
  place-items: center;
  color: #fff;
  border: 4px solid var(--hh-warm-paper, #f9f4e9);
  border-radius: 50%;
  background: var(--hh-deep-2, #315d32);
  box-shadow: 0 4px 12px rgba(25, 59, 31, 0.22);
  transform: translate(-50%, -50%);
}

.hh-story-timeline__icon svg,
.hh-story-belief__icon svg,
.hh-story-love__item > span svg {
  width: 32px;
  height: 32px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.hh-story-timeline__year {
  display: block;
  margin-bottom: 9px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--hh-gold, #bd8933);
}

.hh-story-timeline__card h3 {
  margin-bottom: 12px;
  font-family: var(--hh-serif);
  font-size: 1.62rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--hh-deep, #173c24);
}

.hh-story-timeline__card p {
  margin-bottom: 0;
  font-size: 1rem;
  line-height: 1.72;
  color: #596159;
}

.hh-story-beliefs {
  background: #fff;
}

.hh-story-beliefs .hh-story-heading {
  margin-bottom: 44px;
}

.hh-story-beliefs__grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  width: min(1240px, 100%);
  margin: 0 auto;
}

.hh-story-belief {
  padding: 2px 22px 4px;
  text-align: center;
  border-right: 1px solid rgba(48, 85, 47, 0.13);
}

.hh-story-belief:last-child {
  border-right: 0;
}

.hh-story-belief__icon,
.hh-story-love__item > span {
  display: grid;
  width: 48px;
  height: 48px;
  margin: 0 auto 14px;
  place-items: center;
  color: #668342;
}

.hh-story-belief h3 {
  margin-bottom: 10px;
  font-family: var(--hh-serif);
  font-size: 1.32rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--hh-deep, #173c24);
}

.hh-story-belief p {
  margin-bottom: 0;
  font-size: 0.95rem;
  line-height: 1.7;
  color: #5b625a;
}

.hh-story-standards {
  padding: clamp(72px, 8vw, 112px) 24px;
  border-top: 1px solid rgba(48, 85, 47, 0.1);
  border-bottom: 1px solid rgba(48, 85, 47, 0.1);
  background:
    radial-gradient(circle at 0 100%, rgba(102, 131, 66, 0.13), transparent 28%),
    radial-gradient(circle at 100% 0, rgba(201, 154, 69, 0.12), transparent 28%),
    var(--hh-warm-paper, #f9f4e9);
}

.hh-story-standards__heading {
  width: min(880px, 100%);
  margin: 0 auto clamp(38px, 5vw, 58px);
  text-align: center;
}

.hh-story-standards__heading > span {
  display: block;
  margin-bottom: 10px;
  color: var(--hh-gold, #bd8933);
  font-family: var(--hh-script);
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1;
}

.hh-story-standards__heading h2 {
  margin: 0 0 18px;
  color: var(--hh-deep, #173c24);
  font-family: var(--hh-serif);
  font-size: clamp(38px, 4.6vw, 60px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.02;
}

.hh-story-standards__heading p {
  margin: 0 auto;
  max-width: 760px;
  color: #586258;
  font-family: var(--hh-sans);
  font-size: 16px;
  line-height: 1.75;
}

.hh-story-standards__grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0 auto 28px;
  max-width: 1180px;
}

.hh-story-standard {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(48, 85, 47, 0.12);
  border-radius: 18px;
  box-shadow: 0 16px 38px rgba(39, 58, 36, 0.09);
  overflow: hidden;
  padding: 32px;
  position: relative;
}

.hh-story-standard::before {
  content: "";
  height: 5px;
  inset: 0 0 auto;
  position: absolute;
}

.hh-story-standard--gap::before {
  background: #668342;
}

.hh-story-standard--pgs::before {
  background: #c99a45;
}

.hh-story-standard__header {
  align-items: center;
  display: grid;
  gap: 20px;
  grid-template-columns: 104px minmax(0, 1fr);
  margin-bottom: 22px;
}

.hh-story-standard__header figure {
  align-items: center;
  background: #f8f5eb;
  border: 1px solid rgba(48, 85, 47, 0.1);
  border-radius: 14px;
  display: flex;
  height: 104px;
  justify-content: center;
  margin: 0;
  padding: 14px;
}

.hh-story-standard__header img {
  display: block;
  height: 82px;
  max-width: 100%;
  object-fit: contain;
  width: auto;
}

.hh-story-standard__status {
  background: #eaf3de;
  border-radius: 999px;
  color: #315d32;
  display: inline-block;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.07em;
  margin-bottom: 10px;
  padding: 6px 10px;
  text-transform: uppercase;
}

.hh-story-standard__status--record {
  background: #fff0c9;
  color: #80530f;
}

.hh-story-standard h3 {
  color: var(--hh-deep, #173c24);
  font-family: var(--hh-serif);
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 600;
  line-height: 1.05;
  margin: 0;
}

.hh-story-standard > p {
  color: #566056;
  font-family: var(--hh-sans);
  font-size: 15px;
  line-height: 1.7;
  margin: 0 0 18px;
}

.hh-story-standard > ul {
  color: #33402f;
  display: grid;
  gap: 9px;
  margin: 0 0 20px;
  padding-left: 20px;
}

.hh-story-standard > ul li {
  font-family: var(--hh-sans);
  font-size: 14px;
  line-height: 1.5;
  padding-left: 3px;
}

.hh-story-standard > ul li::marker {
  color: #668342;
}

.hh-story-standard .hh-story-standard__meaning {
  background: #f5f2e8;
  border-left: 4px solid #668342;
  border-radius: 0 10px 10px 0;
  color: #465046;
  margin: 0;
  padding: 15px 17px;
}

.hh-story-standard--pgs .hh-story-standard__meaning {
  border-left-color: #c99a45;
}

.hh-story-practices {
  background:
    radial-gradient(circle at 100% 0, rgba(201, 154, 69, 0.14), transparent 34%),
    var(--hh-deep-2, #315d32);
  border-radius: 20px;
  color: #fff;
  display: grid;
  gap: clamp(30px, 5vw, 64px);
  grid-template-columns: minmax(260px, 0.8fr) minmax(0, 1.2fr);
  margin: 0 auto;
  max-width: 1180px;
  padding: clamp(30px, 5vw, 54px);
}

.hh-story-practices__intro > span {
  color: #efd28d;
  display: block;
  font-family: var(--hh-script);
  font-size: 30px;
  line-height: 1;
  margin-bottom: 10px;
}

.hh-story-practices__intro h3 {
  color: #fff;
  font-family: var(--hh-serif);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 600;
  line-height: 1.03;
  margin: 0 0 16px;
}

.hh-story-practices__intro p {
  color: rgba(255, 255, 255, 0.8);
  font-family: var(--hh-sans);
  font-size: 15px;
  line-height: 1.7;
  margin: 0 0 22px;
}

.hh-story-practices__intro a {
  align-items: center;
  border-bottom: 1px solid #efd28d;
  color: #f6d98d !important;
  display: inline-flex;
  font-size: 13px;
  font-weight: 800;
  gap: 8px;
  letter-spacing: 0.06em;
  padding-bottom: 5px;
  text-decoration: none;
  text-transform: uppercase;
}

.hh-story-practices__intro a:hover {
  color: #fff !important;
  gap: 12px;
}

.hh-story-practices__grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hh-story-practice {
  align-items: flex-start;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.13);
  border-radius: 14px;
  display: flex;
  gap: 13px;
  padding: 18px;
}

.hh-story-practice > span {
  color: #efd28d;
  display: inline-flex;
  flex: 0 0 30px;
  height: 30px;
  width: 30px;
}

.hh-story-practice > span svg {
  fill: none;
  height: 100%;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
  width: 100%;
}

.hh-story-practice strong {
  color: #fff;
  display: block;
  font-family: var(--hh-sans);
  font-size: 14px;
  line-height: 1.35;
  margin-bottom: 5px;
}

.hh-story-practice p {
  color: rgba(255, 255, 255, 0.72);
  font-family: var(--hh-sans);
  font-size: 12px;
  line-height: 1.55;
  margin: 0;
}

.hh-farm-proof {
  background:
    radial-gradient(circle at 0 100%, rgba(102, 131, 66, 0.11), transparent 28%),
    radial-gradient(circle at 100% 0, rgba(201, 154, 69, 0.1), transparent 28%),
    #fffdf8;
  border-bottom: 1px solid rgba(48, 85, 47, 0.1);
  border-top: 1px solid rgba(48, 85, 47, 0.1);
  padding: clamp(64px, 7vw, 92px) 24px;
  scroll-margin-top: 96px;
}

.hh-farm-proof--packages {
  background:
    radial-gradient(circle at 12% 20%, rgba(201, 154, 69, 0.1), transparent 25%),
    linear-gradient(180deg, #f3f6e9, #fffdf8);
}

.hh-farm-proof--farm {
  background:
    radial-gradient(circle at 88% 12%, rgba(201, 154, 69, 0.12), transparent 28%),
    var(--hh-warm-paper, #f9f4e9);
}

.hh-farm-proof__inner {
  margin: 0 auto;
  max-width: 1180px;
}

.hh-farm-proof__heading {
  margin: 0 auto clamp(32px, 4vw, 48px);
  max-width: 820px;
  text-align: center;
}

.hh-farm-proof__heading > span,
.hh-farm-proof__practices-intro > span,
.hh-farm-proof__cert-copy > span {
  color: var(--hh-gold, #bd8933);
  display: block;
  font-family: var(--hh-script);
  font-size: clamp(25px, 3vw, 34px);
  line-height: 1;
  margin-bottom: 10px;
}

.hh-farm-proof__heading h2 {
  color: var(--hh-deep, #173c24);
  font-family: var(--hh-serif);
  font-size: clamp(36px, 4.3vw, 56px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.03;
  margin: 0 0 16px;
}

.hh-farm-proof__heading p {
  color: #586258;
  font-family: var(--hh-sans);
  font-size: 15px;
  line-height: 1.72;
  margin: 0;
}

.hh-farm-proof__standards {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 22px;
}

.hh-farm-proof__standard {
  align-items: center;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(48, 85, 47, 0.12);
  border-radius: 16px;
  box-shadow: 0 14px 34px rgba(39, 58, 36, 0.08);
  display: grid;
  gap: 22px;
  grid-template-columns: 112px minmax(0, 1fr);
  padding: 25px;
}

.hh-farm-proof__standard figure {
  align-items: center;
  background: #f8f5eb;
  border: 1px solid rgba(48, 85, 47, 0.1);
  border-radius: 13px;
  display: flex;
  height: 112px;
  justify-content: center;
  margin: 0;
  padding: 14px;
}

.hh-farm-proof__standard img {
  display: block;
  height: 84px;
  max-width: 100%;
  object-fit: contain;
  width: auto;
}

.hh-farm-proof__status {
  background: #eaf3de;
  border-radius: 999px;
  color: #315d32;
  display: inline-block;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.07em;
  margin-bottom: 8px;
  padding: 5px 9px;
  text-transform: uppercase;
}

.hh-farm-proof__status--record {
  background: #fff0c9;
  color: #80530f;
}

.hh-farm-proof__standard h3 {
  color: var(--hh-deep, #173c24);
  font-family: var(--hh-serif);
  font-size: clamp(24px, 2.5vw, 31px);
  font-weight: 600;
  line-height: 1.08;
  margin: 0 0 9px;
}

.hh-farm-proof__standard p {
  color: #586258;
  font-family: var(--hh-sans);
  font-size: 13px;
  line-height: 1.62;
  margin: 0;
}

.hh-farm-proof__standard .hh-farm-proof__record {
  border-left: 3px solid #668342;
  margin-top: 12px;
  padding-left: 12px;
}

.hh-farm-proof__standard--record .hh-farm-proof__record {
  border-left-color: #c99a45;
}

.hh-farm-proof__practices {
  background:
    radial-gradient(circle at 100% 0, rgba(201, 154, 69, 0.15), transparent 34%),
    var(--hh-deep-2, #315d32);
  border-radius: 18px;
  display: grid;
  gap: clamp(28px, 4vw, 52px);
  grid-template-columns: minmax(250px, 0.78fr) minmax(0, 1.22fr);
  margin-bottom: 22px;
  padding: clamp(28px, 4vw, 44px);
}

.hh-farm-proof__practices-intro > span {
  color: #efd28d;
}

.hh-farm-proof__practices-intro h3 {
  color: #fff;
  font-family: var(--hh-serif);
  font-size: clamp(31px, 3.5vw, 43px);
  font-weight: 600;
  line-height: 1.04;
  margin: 0 0 15px;
}

.hh-farm-proof__practices-intro p {
  color: rgba(255, 255, 255, 0.82);
  font-family: var(--hh-sans);
  font-size: 14px;
  line-height: 1.68;
  margin: 0;
}

.hh-farm-proof__practice-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hh-farm-proof__practice-grid > div {
  align-items: flex-start;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 12px;
  display: flex;
  gap: 12px;
  padding: 16px;
}

.hh-farm-proof__practice-grid > div > span {
  color: #efd28d;
  display: inline-flex;
  flex: 0 0 28px;
  height: 28px;
  width: 28px;
}

.hh-farm-proof__practice-grid svg,
.hh-farm-proof__strip-icon svg {
  fill: none;
  height: 100%;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
  width: 100%;
}

.hh-farm-proof__practice-grid p {
  color: rgba(255, 255, 255, 0.72);
  font-family: var(--hh-sans);
  font-size: 12px;
  line-height: 1.5;
  margin: 0;
}

.hh-farm-proof__practice-grid strong {
  color: #fff;
  display: block;
  font-size: 13px;
  line-height: 1.35;
  margin-bottom: 4px;
}

.hh-farm-proof__certs {
  align-items: center;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(48, 85, 47, 0.12);
  border-radius: 16px;
  box-shadow: 0 14px 34px rgba(39, 58, 36, 0.08);
  display: grid;
  gap: clamp(28px, 4vw, 52px);
  grid-template-columns: minmax(250px, 0.76fr) minmax(0, 1.24fr);
  padding: clamp(25px, 4vw, 40px);
}

.hh-farm-proof__cert-copy h3 {
  color: var(--hh-deep, #173c24);
  font-family: var(--hh-serif);
  font-size: clamp(30px, 3.5vw, 42px);
  font-weight: 600;
  line-height: 1.04;
  margin: 0 0 12px;
}

.hh-farm-proof__cert-copy p {
  color: #586258;
  font-family: var(--hh-sans);
  font-size: 14px;
  line-height: 1.65;
  margin: 0 0 17px;
}

.hh-farm-proof__cert-copy a {
  align-items: center;
  border-bottom: 1px solid var(--hh-gold, #bd8933);
  color: var(--hh-deep-2, #315d32) !important;
  display: inline-flex;
  font-size: 12px;
  font-weight: 800;
  gap: 8px;
  letter-spacing: 0.05em;
  padding-bottom: 5px;
  text-decoration: none !important;
  text-transform: uppercase;
}

.hh-farm-proof__cert-copy a:hover {
  color: var(--hh-gold, #bd8933) !important;
  gap: 12px;
}

.hh-farm-proof__credentials {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}

.hh-farm-proof__credentials figure {
  background: #f8f5eb;
  border: 1px solid rgba(48, 85, 47, 0.11);
  border-radius: 12px;
  flex: 0 1 calc(33.333% - 8px);
  margin: 0;
  padding: 14px 12px 12px;
  text-align: center;
}

.hh-farm-proof__credentials img {
  display: block;
  height: 82px;
  margin: 0 auto 9px;
  max-width: 100%;
  object-fit: contain;
  width: auto;
}

.hh-farm-proof__credentials .hh-farm-proof__license img {
  border: 1px solid rgba(48, 85, 47, 0.12);
}

.hh-farm-proof__credentials figcaption {
  color: #536052;
  font-family: var(--hh-sans);
  font-size: 10px;
  font-weight: 700;
  line-height: 1.35;
}

.hh-farm-proof--strip {
  background: var(--hh-deep-2, #315d32);
  padding: 40px 24px;
}

.hh-farm-proof__strip {
  align-items: stretch;
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(230px, 1.1fr) repeat(3, minmax(0, 1fr));
  margin: 0 auto;
  max-width: 1180px;
}

.hh-farm-proof__strip-intro,
.hh-farm-proof__strip article {
  border-radius: 12px;
  padding: 22px;
}

.hh-farm-proof__strip-intro {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.hh-farm-proof__strip-intro > span,
.hh-farm-proof__strip small {
  color: #efd28d;
  display: block;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.09em;
  margin-bottom: 7px;
  text-transform: uppercase;
}

.hh-farm-proof__strip-intro h2 {
  color: #fff;
  font-family: var(--hh-serif);
  font-size: 27px;
  font-weight: 600;
  line-height: 1.04;
  margin: 0 0 10px;
}

.hh-farm-proof__strip-intro p,
.hh-farm-proof__strip article p {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  line-height: 1.55;
  margin: 0;
}

.hh-farm-proof__strip article {
  align-items: flex-start;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.14);
  display: flex;
  gap: 12px;
}

.hh-farm-proof__strip-icon {
  color: #efd28d;
  display: inline-flex;
  flex: 0 0 30px;
  height: 30px;
  width: 30px;
}

.hh-farm-proof__strip h3 {
  color: #fff;
  font-family: var(--hh-serif);
  font-size: 19px;
  font-weight: 600;
  line-height: 1.1;
  margin: 0 0 8px;
}

.hh-farm-proof__mini-logos {
  display: flex;
  flex: 0 0 58px;
  flex-direction: column;
  gap: 5px;
}

.hh-farm-proof__mini-logos img {
  background: #fff;
  border-radius: 6px;
  display: block;
  height: 38px;
  object-fit: contain;
  padding: 4px;
  width: 58px;
}

.hh-farm-proof__strip-certs a {
  color: #efd28d !important;
  font-size: 11px;
  font-weight: 800;
  text-decoration: none !important;
  text-transform: uppercase;
}

.hh-farm-proof__strip-certs a:hover {
  color: #fff !important;
}

@media (max-width: 980px) {
  .hh-farm-proof__standards,
  .hh-farm-proof__practices,
  .hh-farm-proof__certs {
    grid-template-columns: 1fr;
  }

  .hh-farm-proof__strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .hh-farm-proof {
    padding: 54px 18px;
  }

  .hh-farm-proof__standard {
    align-items: flex-start;
    grid-template-columns: 82px minmax(0, 1fr);
    padding: 18px;
  }

  .hh-farm-proof__standard figure {
    height: 82px;
    padding: 9px;
  }

  .hh-farm-proof__standard img {
    height: 62px;
  }

  .hh-farm-proof__practice-grid,
  .hh-farm-proof__credentials,
  .hh-farm-proof__strip {
    grid-template-columns: 1fr;
  }

  .hh-farm-proof__practices,
  .hh-farm-proof__certs {
    padding: 24px 20px;
  }

  .hh-farm-proof__credentials figure {
    align-items: center;
    display: grid;
    flex-basis: 100%;
    gap: 14px;
    grid-template-columns: 86px minmax(0, 1fr);
    text-align: left;
  }

  .hh-farm-proof__credentials img {
    height: 66px;
    margin: 0 auto;
  }

  .hh-farm-proof--strip {
    padding: 36px 18px;
  }
}

.hh-story-certifications {
  background: #fffdf8;
  padding: clamp(68px, 8vw, 104px) 24px;
  scroll-margin-top: 96px;
}

.hh-story-certifications__heading {
  margin: 0 auto clamp(34px, 5vw, 52px);
  max-width: 780px;
  text-align: center;
}

.hh-story-certifications__heading > span {
  color: var(--hh-gold, #bd8933);
  display: block;
  font-family: var(--hh-script);
  font-size: clamp(28px, 3vw, 38px);
  line-height: 1;
  margin-bottom: 10px;
}

.hh-story-certifications__heading h2 {
  color: var(--hh-deep, #173c24);
  font-family: var(--hh-serif);
  font-size: clamp(38px, 4.6vw, 58px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.03;
  margin: 0 0 16px;
}

.hh-story-certifications__heading p {
  color: #586258;
  font-family: var(--hh-sans);
  font-size: 15px;
  line-height: 1.7;
  margin: 0;
}

.hh-story-video {
  position: relative;
  padding: clamp(60px, 7vw, 88px) 24px;
  color: #fff;
  background:
    radial-gradient(circle at 76% 48%, rgba(157, 129, 58, 0.15), transparent 34%),
    #172d19;
}

.hh-story-video__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: clamp(38px, 6vw, 76px);
  align-items: center;
  width: min(1180px, 100%);
  margin: 0 auto;
}

.hh-story-video__preview {
  position: relative;
  display: block;
  width: 100%;
  overflow: hidden;
  margin: 0;
  padding: 0;
  aspect-ratio: 16 / 9;
  border: 2px solid rgba(217, 174, 83, 0.78);
  border-radius: 9px;
  background: #17351e;
  box-shadow: 0 22px 42px rgba(0, 0, 0, 0.24);
  cursor: pointer;
}

.hh-story-video__preview::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(0deg, rgba(9, 26, 13, 0.34), transparent 65%);
}

.hh-story-video__preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hh-story-video__play {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  display: grid;
  width: 76px;
  height: 76px;
  place-items: center;
  color: #fff;
  border: 2px solid #fff;
  border-radius: 50%;
  background: rgba(32, 67, 35, 0.58);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
  transform: translate(-50%, -50%);
  transition: background 200ms ease, transform 200ms ease;
}

.hh-story-video__preview:hover .hh-story-video__play {
  background: var(--hh-gold, #bd8933);
  transform: translate(-50%, -50%) scale(1.05);
}

.hh-story-video__play::before {
  width: 0;
  height: 0;
  margin-left: 6px;
  content: "";
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
  border-left: 18px solid currentColor;
}

.hh-story-video__copy > span {
  display: block;
  margin-bottom: 12px;
  font-family: var(--hh-script);
  font-size: clamp(1.3rem, 2vw, 1.75rem);
  color: var(--hh-gold, #d6a447);
}

.hh-story-video__copy h2 {
  margin-bottom: 18px;
  font-size: clamp(36px, 4.2vw, 58px);
  line-height: 1.03;
  color: #fff;
}

.hh-story-video__copy p {
  max-width: 520px;
  margin-bottom: 24px;
  font-size: 1.05rem;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.8);
}

.hh-story-video__button {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  padding: 12px 23px;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  border: 1px solid #698247;
  border-radius: 4px;
  background: #4e6c38;
  cursor: pointer;
  transition: background 180ms ease, transform 180ms ease;
}

.hh-story-video__button:hover {
  color: #fff;
  background: #698247;
  transform: translateY(-2px);
}

.hh-story-love {
  padding-top: clamp(58px, 6vw, 84px);
  padding-bottom: clamp(56px, 6vw, 82px);
  background: var(--hh-warm-paper, #f9f4e9);
}

.hh-story-love > h2 {
  margin: 0 auto 38px;
  font-family: var(--hh-serif);
  font-size: clamp(34px, 3.8vw, 52px);
  font-weight: 600;
  line-height: 1.05;
  text-align: center;
  color: var(--hh-deep, #173c24);
}

.hh-story-love__grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  width: min(1260px, 100%);
  margin: 0 auto;
}

.hh-story-love__item {
  padding: 0 14px;
  text-align: center;
  border-right: 1px solid rgba(49, 91, 50, 0.13);
}

.hh-story-love__item:last-child {
  border-right: 0;
}

.hh-story-love__item > span {
  margin-bottom: 10px;
}

.hh-story-love__item strong {
  display: block;
  margin-bottom: 0;
  font-family: var(--hh-sans);
  font-size: 0.98rem;
  font-weight: 600;
  line-height: 1.35;
  color: #243426;
}

.hh-story-cta {
  position: relative;
  display: grid;
  min-height: 430px;
  padding: 76px 24px;
  place-items: center;
  color: #fff;
  background-position: center;
  background-size: cover;
  background-image: var(--hh-story-cta-image);
}

.hh-story-cta::before {
  position: absolute;
  inset: 0;
  content: "";
  background:
    linear-gradient(90deg, rgba(12, 43, 21, 0.92), rgba(18, 54, 25, 0.82) 50%, rgba(10, 38, 17, 0.92)),
    linear-gradient(0deg, rgba(8, 29, 14, 0.55), transparent);
}

.hh-story-cta__inner {
  position: relative;
  z-index: 1;
  width: min(840px, 100%);
  text-align: center;
}

.hh-story-cta__inner > span {
  display: block;
  margin: 0 0 10px;
  font-family: var(--hh-script);
  font-size: clamp(30px, 3.2vw, 46px);
  line-height: 1;
  color: var(--hh-gold);
}

.hh-story-cta h2 {
  max-width: 820px;
  margin: 0 auto 22px;
  font-size: clamp(36px, 4.2vw, 58px);
  line-height: 0.98;
  color: #fff;
}

.hh-story-cta p {
  width: min(650px, 100%);
  margin: 0 auto;
  font-size: 15px;
  line-height: 1.7;
  color: rgba(255, 253, 248, 0.82);
}

.hh-story-cta__actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  margin-top: 32px;
}

.hh-story-cta__actions a {
  display: inline-flex;
  min-width: 204px;
  min-height: 52px;
  align-items: center;
  justify-content: center;
  padding: 15px 22px;
  font-family: var(--hh-sans);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: 0;
  text-transform: none;
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 8px;
  text-decoration: none !important;
  transition: color 180ms ease, background 180ms ease, transform 180ms ease;
}

body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:first-child,
body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:first-child:visited {
  color: #fff !important;
  border-color: var(--hh-gold, #d6a447);
  background: var(--hh-gold, #d6a447);
}

body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:nth-child(2),
body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:nth-child(2):visited {
  color: var(--hh-deep-2) !important;
  border-color: rgba(255, 253, 248, 0.88);
  background: rgba(255, 253, 248, 0.97);
}

body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:last-child,
body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:last-child:visited {
  color: #fff !important;
  border-color: #6f914f;
  background: #496f35;
}

body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:first-child:hover,
body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:first-child:focus-visible {
  color: #fff !important;
  border-color: #d1a452;
  background: #d1a452;
  transform: translateY(-2px);
}

body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:nth-child(2):hover,
body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:nth-child(2):focus-visible {
  color: var(--hh-forest) !important;
  border-color: #fff;
  background: #fff;
  transform: translateY(-2px);
}

body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:last-child:hover,
body.happy-herb-redesign.hh-our-story-page .hh-story-cta__actions a:last-child:focus-visible {
  color: #fff !important;
  border-color: #5f8846;
  background: #5f8846;
  transform: translateY(-2px);
}

.hh-story-video-modal[hidden] {
  display: none;
}

.hh-story-video-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: grid;
  padding: 24px;
  place-items: center;
}

.hh-story-video-modal__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(4, 16, 8, 0.88);
  cursor: pointer;
}

.hh-story-video-modal__panel {
  position: relative;
  z-index: 1;
  width: min(960px, 100%);
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 10px;
  background: #0c1710;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.48);
}

.hh-story-video-modal__panel video {
  display: block;
  width: 100%;
  max-height: 78vh;
  border-radius: 5px;
  background: #000;
}

.hh-story-video-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 8px 14px;
}

.hh-story-video-modal__header h2 {
  margin: 0;
  font-family: var(--hh-serif);
  font-size: 1.45rem;
  font-weight: 500;
  color: #fff;
}

.hh-story-video-modal__header button {
  position: absolute;
  top: -18px;
  right: -18px;
  z-index: 2;
  display: grid;
  width: 42px;
  height: 42px;
  padding: 0;
  place-items: center;
  font-size: 1.55rem;
  line-height: 1;
  color: #173c24;
  border: 0;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.24);
  cursor: pointer;
}

html.hh-story-video-is-open {
  overflow: hidden;
}

@media (max-width: 1100px) {
  .hh-story-founder__inner {
    grid-template-columns: 1fr;
  }

  .hh-story-founder__copy {
    width: min(720px, 100%);
  }

  .hh-story-timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: 56px;
  }

  .hh-story-timeline::before {
    display: none;
  }

  .hh-story-beliefs__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 38px 0;
  }

  .hh-story-belief:nth-child(3) {
    border-right: 0;
  }

  .hh-story-love__grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 34px 0;
  }

  .hh-story-love__item:nth-child(4) {
    border-right: 0;
  }
}

@media (max-width: 900px) {
  .hh-story-standards__grid,
  .hh-story-practices {
    grid-template-columns: 1fr;
  }

  .hh-story-practices__intro {
    max-width: 650px;
  }

  .hh-story-video__inner {
    grid-template-columns: 1fr;
  }

  .hh-story-video__copy {
    width: min(680px, 100%);
  }
}

@media (max-width: 767px) {
  body.happy-herb-redesign.hh-ref-header-dark.hh-our-story-page #site-header,
  body.admin-bar.happy-herb-redesign.hh-ref-header-dark.hh-our-story-page #site-header {
    position: relative;
    top: auto;
    background: #12351d;
  }

  .hh-story-hero {
    min-height: var(--hh-ref-hero-height);
  }

  .hh-story-hero::before {
    background-position: 68% center;
  }

  .hh-story-hero .hh-ref-hero__inner {
    min-height: var(--hh-ref-hero-height);
    padding-top: 76px;
    padding-bottom: 24px;
  }

  .hh-story-hero .hh-ref-hero__shade {
    background:
      linear-gradient(90deg, rgba(8, 27, 15, 0.88), rgba(8, 27, 15, 0.58)),
      linear-gradient(0deg, rgba(8, 27, 15, 0.55), transparent 55%);
  }

  .hh-story-hero h1 {
    font-size: clamp(2.75rem, 13vw, 4.15rem);
  }

  .hh-story-hero .hh-ref-hero__actions,
  .hh-story-cta__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .hh-story-hero .hh-ref-button,
  .hh-story-cta__actions a {
    width: 100%;
  }

  .hh-story-founder,
  .hh-story-journey,
  .hh-story-beliefs,
  .hh-story-standards,
  .hh-story-certifications,
  .hh-story-love {
    padding-right: 18px;
    padding-left: 18px;
  }

  .hh-story-standard {
    padding: 24px;
  }

  .hh-story-standard__header {
    grid-template-columns: 86px minmax(0, 1fr);
  }

  .hh-story-standard__header figure {
    height: 86px;
    padding: 10px;
  }

  .hh-story-standard__header img {
    height: 68px;
  }

  .hh-story-practices {
    border-radius: 16px;
    padding: 26px 22px;
  }

  .hh-story-founder__gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: 360px 170px;
    min-height: 0;
  }

  .hh-story-founder__gallery .hh-story-founder__main {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  .hh-story-founder__gallery::before {
    display: none;
  }

  .hh-story-timeline {
    grid-template-columns: 1fr;
  }

  .hh-story-timeline__card {
    min-height: 0;
  }

  .hh-story-beliefs__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 36px 0;
  }

  .hh-story-belief {
    padding-right: 14px;
    padding-left: 14px;
  }

  .hh-story-belief:nth-child(3) {
    border-right: 1px solid rgba(48, 85, 47, 0.13);
  }

  .hh-story-belief:nth-child(even) {
    border-right: 0;
  }

  .hh-story-love__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hh-story-love__item {
    padding-right: 10px;
    padding-left: 10px;
  }

  .hh-story-love__item:nth-child(odd) {
    border-right: 1px solid rgba(49, 91, 50, 0.13);
  }

  .hh-story-love__item:nth-child(even) {
    border-right: 0;
  }

  .hh-story-cta {
    min-height: 470px;
    padding-right: 18px;
    padding-left: 18px;
  }

  .hh-story-video-modal {
    padding: 14px;
  }

  .hh-story-video-modal__header button {
    top: -14px;
    right: -8px;
  }
}

@media (max-width: 480px) {
  .hh-story-founder__gallery {
    grid-template-rows: 310px 130px;
    gap: 9px;
  }

  .hh-story-belief p {
    font-size: 0.9rem;
  }

  .hh-story-standards__heading h2 {
    font-size: 36px;
  }

  .hh-story-standard__header {
    align-items: start;
    grid-template-columns: 70px minmax(0, 1fr);
    gap: 14px;
  }

  .hh-story-standard__header figure {
    height: 70px;
  }

  .hh-story-standard__header img {
    height: 54px;
  }

  .hh-story-standard__status {
    font-size: 8px;
    line-height: 1.35;
  }

  .hh-story-practices__grid {
    grid-template-columns: 1fr;
  }

  .hh-story-video {
    padding-right: 18px;
    padding-left: 18px;
  }

  .hh-story-video__play {
    width: 62px;
    height: 62px;
  }
}

/* ============================================================
   SINGLE TRIP — MOCKUP HERO (P8)
   ============================================================ */
.single-trip .wpte-gallery-wrapper__multi-banners{ display:none !important; } /* custom hero replaces WPTE gallery */
.single-trip .entry-title{ display:none; }                                    /* title now lives in the hero */

.hh-tp-hero{ position:relative; background:var(--hh-tp-bg) center var(--hh-tp-pos, 32%)/cover no-repeat; min-height:60vh; display:flex; align-items:center; }
.hh-tp-hero__overlay{ position:absolute; inset:0; background:linear-gradient(95deg, rgba(18,28,16,.88) 0%, rgba(18,28,16,.64) 42%, rgba(18,28,16,.14) 72%, rgba(18,28,16,0) 100%); }
.hh-tp-hero__inner{ position:relative; width:100%; max-width:1280px; margin:0 auto; padding:60px 24px; }
.hh-tp-hero__content{ max-width:940px; color:#fff; }
.hh-tp-breadcrumb{ font-size:14px; letter-spacing:.04em; margin-bottom:20px; color:#fff; }
.hh-tp-breadcrumb a{ color:#fff !important; font-weight:700; opacity:1; text-decoration:none; text-shadow:0 1px 4px rgba(0,0,0,.45); }
.hh-tp-breadcrumb a:hover,
.hh-tp-breadcrumb a:focus{ color:#f3d28d !important; text-decoration:underline; }
.hh-tp-breadcrumb > span:not(.hh-tp-breadcrumb__current){ color:#fff; margin:0 8px; opacity:1; }
.hh-tp-breadcrumb .hh-tp-breadcrumb__current{ color:#fff; font-size:16px; font-weight:700; opacity:1; }
.hh-tp-hero__title{ font-family:'Cormorant Garamond',serif; font-weight:600; font-size:4rem; line-height:1.02; margin:0 0 10px; color:#fff; }
.hh-tp-hero__tag{ font-family:'Dancing Script','Segoe Script','Brush Script MT',cursive; font-size:22px; font-style:normal; font-weight:600; color:#E0B45F; margin:0 0 18px; }
.hh-tp-hero__desc{ font-size:1.1rem; line-height:1.65; color:#EDEADD; margin:0 0 30px; max-width:580px; }
.hh-tp-badges{ display:grid; gap:18px 34px; grid-template-columns:repeat(4,max-content); justify-content:start; list-style:none; margin:0; max-width:100%; padding:0; }
.hh-tp-badges li{ display:flex; align-items:center; gap:8px; min-width:0; }
.hh-tp-badge__ic{ color:#E0B45F; flex:0 0 auto; display:flex; }
.hh-tp-badge__tx{ display:flex; flex-direction:column; line-height:1.3; }
.hh-tp-badge__tx strong{ color:#fff; font-size:12px; font-weight:700; }
.hh-tp-badge__tx small{ color:#fff; font-size:12px; white-space:nowrap; }

.hh-tp-program{ background:#fffdf8; border-bottom:1px solid rgba(73,111,53,.12); padding:34px 24px 38px; }
.hh-tp-program__inner{ max-width:980px; margin:0 auto; text-align:center; }
.hh-tp-program__label{ background:#245a2d; border-radius:4px; color:#fff; font-family:'Cormorant Garamond',serif; font-size:17px; font-weight:700; letter-spacing:.04em; line-height:1; margin:0 0 18px; padding:10px 18px; text-transform:uppercase; }
.hh-tp-program__label::after{ border-left:5px solid transparent; border-right:5px solid transparent; border-top:7px solid #245a2d; content:""; display:block; height:0; left:50%; position:absolute; top:100%; transform:translateX(-50%); width:0; }
.hh-tp-program__label{ position:relative; }
.hh-tp-program h2{ color:#20351d; font-family:'Cormorant Garamond',serif; font-size:38px; font-weight:600; line-height:1.08; margin:0 0 22px; }
.hh-tp-program__cards{ display:flex; gap:24px; justify-content:center; margin:0 auto; max-width:660px; }
.hh-tp-program__card{ align-items:center; background:#fff; border:1px solid #d8b660; border-radius:9px; color:#20351d; display:flex; flex:1 1 0; gap:12px; justify-content:center; min-height:78px; padding:14px 20px; text-align:left; }
.hh-tp-program__card.is-primary{ background:#2f6b38; border-color:#2f6b38; color:#fff; }
.hh-tp-program__icon{ color:#dca62c; display:flex; flex:0 0 auto; }
.hh-tp-program__card h3{ color:inherit; font-family:'DM Sans','Helvetica Neue',Arial,sans-serif; font-size:16px; font-weight:700; line-height:1.25; margin:0 0 4px; }
.hh-tp-program__card p{ color:inherit; font-size:14px; font-weight:600; line-height:1.3; margin:0; opacity:.86; }
.hh-tp-program__note{ color:#5f6b62; font-size:14px; line-height:1.6; margin:20px auto 0; max-width:760px; }

@media (max-width:900px){
	.hh-tp-hero{ min-height:auto; }
	.hh-tp-hero__overlay{ background:linear-gradient(180deg, rgba(18,28,16,.55), rgba(18,28,16,.85)); }
	.hh-tp-hero__title{ font-size:3rem; }
	.hh-tp-hero__tag{ font-size:22px; }
	.hh-tp-badges{ gap:14px 28px; grid-template-columns:repeat(2,max-content); }
}

/* ============================================================
   FARM UPDATES — "This Week" featured latest post (P9)
   ============================================================ */
.hh-farm-week__layout--latest{ display:grid; grid-template-columns:1.15fr 1fr; gap:34px; align-items:center; }
.hh-farm-week__feature{ display:block; min-height:340px; border-radius:18px; background-size:cover; background-position:center; box-shadow:0 16px 40px rgba(32,53,29,.14); }
.hh-farm-week__layout--latest .hh-farm-week__note h3{ margin:.2em 0 .4em; }
.hh-farm-week__layout--latest .hh-farm-week__note h3 a{ color:inherit; text-decoration:none; }
.hh-farm-week__layout--latest .hh-farm-week__note h3 a:hover{ color:#496F35; }
.hh-farm-week__btn{ display:inline-block; margin-top:10px; background:#496F35; color:#fff !important; text-decoration:none; padding:11px 24px; border-radius:999px; font-weight:700; letter-spacing:.02em; transition:background .2s ease; }
.hh-farm-week__btn:hover{ background:#20351D; }
@media (max-width:860px){ .hh-farm-week__layout--latest{ grid-template-columns:1fr; gap:20px; } .hh-farm-week__feature{ min-height:220px; } }

/* ============================================================
   SINGLE TRIP — MOCKUP SECTIONS: gallery / FAQ / CTA / trust (P8)
   ============================================================ */
.hh-tp-section-head{ text-align:center; max-width:680px; margin:0 auto 34px; }
.hh-tp-section-head span{ display:block; font-size:18px; letter-spacing:.12em; text-transform:uppercase; color:#C9973F; font-weight:700; margin-bottom:10px; }
.hh-tp-section-head h2{ font-family:'Cormorant Garamond',serif; font-size:2.75rem; line-height:1.08; color:#20351D; margin:0; }

.hh-tp-gallery{ max-width:1180px; margin:0 auto; padding:60px 24px 12px; }
.hh-tp-gallery__grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.hh-tp-gallery__item{ margin:0; border-radius:12px; overflow:hidden; aspect-ratio:1/1; }
.hh-tp-gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; display:block; }
.hh-tp-gallery__item:hover img{ transform:scale(1.06); }

.hh-tp-faq{ max-width:1000px; margin:0 auto; padding:60px 24px; }
.hh-tp-faq__grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px 22px; }
.hh-tp-faq__item{ background:#FBF6EC; border:1px solid #E4E2D4; border-radius:10px; }
.hh-tp-faq__item summary{ list-style:none; cursor:pointer; padding:18px 20px; font-size:18px; line-height:1.45; font-weight:700; color:#20351D; display:flex; justify-content:space-between; align-items:center; gap:12px; }
.hh-tp-faq__item summary::-webkit-details-marker{ display:none; }
.hh-tp-faq__plus{ width:16px; height:16px; position:relative; flex:0 0 auto; }
.hh-tp-faq__plus::before,.hh-tp-faq__plus::after{ content:""; position:absolute; background:#496F35; }
.hh-tp-faq__plus::before{ top:7px; left:0; width:16px; height:2px; }
.hh-tp-faq__plus::after{ left:7px; top:0; width:2px; height:16px; transition:transform .2s, opacity .2s; }
.hh-tp-faq__item[open] .hh-tp-faq__plus::after{ transform:rotate(90deg); opacity:0; }
.hh-tp-faq__item p{ margin:0; padding:0 20px 20px; color:#4A5343; font-size:16px; line-height:1.65; }

.hh-tp-cta{ position:relative; background:var(--hh-tp-cta-bg) center/cover no-repeat; margin-top:46px; }
.hh-tp-cta__overlay{ position:absolute; inset:0; background:linear-gradient(90deg, rgba(20,33,18,.93), rgba(20,33,18,.6)); }
.hh-tp-cta__inner{ position:relative; max-width:1180px; margin:0 auto; padding:56px 24px; display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; }
.hh-tp-cta__copy h2{ font-family:'Cormorant Garamond',serif; font-size:2.2rem; color:#fff; margin:0 0 8px; }
.hh-tp-cta__copy p{ color:#E7E2D2; margin:0; max-width:460px; }
.hh-tp-cta__actions{ display:flex; gap:14px; flex-wrap:wrap; }
.hh-tp-cta__btn{ display:inline-block; padding:14px 26px; border-radius:999px; font-weight:700; text-decoration:none; transition:background .2s ease, color .2s ease; }
.hh-tp-cta__btn--primary{ background:#C9973F; color:#20351D; }
.hh-tp-cta__btn--primary:hover{ background:#dca74a; color:#20351D; }
.hh-tp-cta__btn--whatsapp{ background:#fff; border:1.5px solid #fff; box-shadow:0 8px 22px rgba(0,0,0,.16); color:#20351d; }
.hh-tp-cta__btn--whatsapp:hover{ background:#f4eedf; border-color:#f4eedf; color:#20351d; }

.hh-tp-trust{ background:#1B2C18; }
.hh-tp-trust__inner{ max-width:1180px; margin:0 auto; padding:22px 24px; display:flex; justify-content:space-around; gap:18px; flex-wrap:wrap; }
.hh-tp-trust__item{ display:flex; align-items:center; gap:10px; color:#EDEADD; font-size:16px; font-weight:600; }
.hh-tp-trust__item svg{ color:#E0B45F; width:20px; height:20px; }

@media (max-width:860px){
	.hh-tp-gallery__grid{ grid-template-columns:repeat(2,1fr); }
	.hh-tp-faq__grid{ grid-template-columns:1fr; }
	.hh-tp-cta__inner{ flex-direction:column; align-items:flex-start; }
	.hh-tp-section-head h2{ font-size:2.25rem; }
	.hh-tp-program h2{ font-size:32px; }
}

/* Booking card — free cancellation + guest reviews (P8) */
.single-trip .hh-bk-cancel{ margin:12px 0 0; text-align:center; font-size:10px !important; line-height:1.5; color:#6B7263; }
.single-trip .hh-bk-cancel::before{ content:"\2713 "; color:#496F35; font-weight:700; }
.single-trip .hh-bk-reviews{ margin-top:16px; border-top:1px solid #EEEADD; padding-top:14px; }
.single-trip .hh-bk-reviews__h{ font-family:'Cormorant Garamond',serif; font-weight:700; font-size:24px; color:#20351D; margin:0 0 12px; }
.single-trip .hh-bk-review{ margin:0 0 14px; padding:0; font-size:12px !important; line-height:1.55; color:#46503C; font-style:italic; }
.single-trip .hh-bk-review__stars{ display:block; color:#E0B45F; font-style:normal; font-size:12px !important; letter-spacing:1px; }
.single-trip .hh-bk-review cite{ display:block; font-style:normal; font-weight:600; color:#747865; font-size:12px !important; margin-top:4px; }

.single-trip .hh-font-min-14 {
	font-size: 14px !important;
}

.single-trip .enquiry-form-title{ color:#20351d; font-family:'Cormorant Garamond',serif; font-size:30px; line-height:1.15; margin-bottom:10px; }
.single-trip .hh-enquiry-intro{ background:#f7f2e7; border-left:4px solid #c9973f; color:#46503c; font-size:16px; line-height:1.65; margin:0 0 24px; padding:15px 18px; }
.single-trip .hh-enquiry-intro a{ color:#496f35; font-weight:700; }
.single-trip .hh-enquiry-date-note{ color:#6b7263; display:block; font-size:14px; line-height:1.45; margin-top:7px; }

.single-trip .hh-half-itinerary{ margin:38px 0 10px; }
.single-trip .hh-half-itinerary__heading{ border-bottom:0; margin-bottom:0; padding-bottom:10px; }
.single-trip .hh-half-itinerary__heading > span{ color:#496f35; display:block; font-size:14px; margin-bottom:13px; }
.single-trip .hh-half-itinerary__heading > div{ align-items:center; display:flex; gap:20px; justify-content:space-between; }
.single-trip .hh-half-itinerary__heading h2{ color:#302f2c; font-family:'Cormorant Garamond',serif; font-size:34px; font-weight:600; line-height:1.1; margin:0; }
.single-trip .hh-half-itinerary__heading p{ color:#26312b; font-size:16px; line-height:1.65; margin:32px 0 0; }
.single-trip [data-hh-itinerary-toggle-all]{
	background:#fff !important;
	border:1px solid #496f35 !important;
	border-radius:7px;
	color:#30552f !important;
	cursor:pointer;
	flex:0 0 auto;
	font-size:14px;
	font-weight:700;
	line-height:1.2;
	padding:10px 14px;
}
.single-trip [data-hh-itinerary-toggle-all]:hover,
.single-trip [data-hh-itinerary-toggle-all]:focus,
.single-trip [data-hh-itinerary-toggle-all]:active{
	background:#496f35 !important;
	border-color:#496f35 !important;
	color:#fff !important;
	outline:none;
}
.single-trip [data-hh-itinerary-toggle-all]:focus-visible{
	box-shadow:0 0 0 3px rgba(73,111,53,.24);
}
.single-trip .hh-half-itinerary__tabs{ display:flex; gap:10px; margin:18px 0 8px; }
.single-trip .hh-half-itinerary__tabs button{ background:#fff; border:1px solid #d8ded4; border-radius:6px; color:#496f35; cursor:pointer; min-width:185px; padding:9px 14px; text-align:left; }
.single-trip .hh-half-itinerary__tabs button.is-active{ background:#496f35; color:#fff; }
.single-trip .hh-half-itinerary__tabs strong{ color:inherit; display:block; font-size:14px; margin-bottom:2px; }
.single-trip .hh-half-itinerary__tabs span{ color:inherit; display:block; font-size:14px; opacity:.9; }
.single-trip .hh-half-itinerary__panel{ display:none; }
.single-trip .hh-half-itinerary__panel.is-active{ display:block; }
.single-trip .hh-half-itinerary__row{ border-bottom:1px solid #e4e2d4; margin:0; padding-left:64px; position:relative; }
.single-trip .hh-half-itinerary__row::before{ background:#fff; border:2px solid #496f35; border-radius:50%; content:""; height:11px; left:17px; position:absolute; top:31px; width:11px; z-index:1; }
.single-trip .hh-half-itinerary__row.is-first::before{ display:none; }
.single-trip .hh-half-itinerary__first-icon{ align-items:center; background:#496f35; border-radius:50%; color:#fff; display:flex; font-size:25px; height:48px; justify-content:center; left:0; position:absolute; top:18px; width:48px; z-index:2; }
.single-trip .hh-half-itinerary__row::after{ border-left:1px dashed #d5dfd0; bottom:-1px; content:""; left:22px; position:absolute; top:42px; width:0; }
.single-trip .hh-half-itinerary__row.is-first::after{ top:66px; }
.single-trip .hh-half-itinerary__row:last-child::after{ display:none; }
.single-trip .hh-half-itinerary__row summary{ align-items:center; cursor:pointer; display:flex; gap:0; list-style:none; padding:26px 0 18px; position:relative; }
.single-trip .hh-half-itinerary__row summary::-webkit-details-marker{ display:none; }
.single-trip .hh-half-itinerary__time{ color:#132312; flex:0 0 auto; font-size:16px; font-weight:800; }
.single-trip .hh-half-itinerary__row summary strong{ color:#132312; flex:1 1 auto; font-size:16px; line-height:1.4; }
.single-trip .hh-half-itinerary__row summary strong::before{ content:" : "; }
.single-trip .hh-half-itinerary__chevron{ border-bottom:2px solid #496f35; border-right:2px solid #496f35; flex:0 0 auto; height:7px; margin-left:16px; transform:rotate(45deg); transition:transform .2s ease; width:7px; }
.single-trip .hh-half-itinerary__row[open] .hh-half-itinerary__chevron{ transform:rotate(225deg); }
.single-trip .hh-half-itinerary__content{ padding:0 34px 28px 0; }
.single-trip .hh-half-itinerary__content p{ color:#46503c; font-size:16px; line-height:1.65; margin:0; }

/* ============================================================
   SINGLE TRIP — MOBILE polish (P8, ≤600px)
   ============================================================ */
@media (max-width:600px){
	.hh-tp-hero{ min-height:auto; }
	.hh-tp-hero__inner{ padding:40px 18px; }
	.hh-tp-hero__content{ max-width:100%; }
	.hh-tp-hero__overlay{ background:linear-gradient(180deg, rgba(18,28,16,.5), rgba(18,28,16,.88)); }
	.hh-tp-hero__title{ font-size:2.35rem; }
	.hh-tp-hero__tag{ font-size:22px; }
	.hh-tp-hero__desc{ font-size:1rem; max-width:100%; }
	.hh-tp-badges{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:14px 16px; width:100%; }
	.hh-tp-program{ padding:28px 18px 32px; }
	.hh-tp-program__label{ font-size:16px; }
	.hh-tp-program h2{ font-size:29px; margin-bottom:18px; }
	.hh-tp-program__cards{ flex-direction:column; gap:12px; }
	.hh-tp-program__card{ justify-content:flex-start; min-height:72px; width:100%; }

	.hh-tp-section-head span{ font-size:16px; }
	.hh-tp-section-head h2{ font-size:2rem; }
	.hh-tp-gallery{ padding:42px 18px 6px; }
	.hh-tp-gallery__grid{ grid-template-columns:repeat(2,1fr); gap:10px; }
	.hh-tp-faq{ padding:42px 18px; }
	.hh-tp-faq__grid{ grid-template-columns:1fr; }

	.hh-tp-cta__inner{ flex-direction:column; align-items:flex-start; padding:40px 18px; }
	.hh-tp-cta__copy h2{ font-size:1.65rem; }
	.hh-tp-cta__actions{ width:100%; }
	.hh-tp-cta__btn{ flex:1 1 auto; text-align:center; }

	.hh-tp-trust__inner{ gap:12px 14px; padding:20px 18px; }
	.hh-tp-trust__item{ flex:1 1 44%; justify-content:flex-start; }

	/* booking sidebar stacks below content on mobile — never sticky */
	.single-trip .widget-area .wpte-booking-area-wrapper{ position:static !important; }
	.single-trip .wpte-booking-area.wpte-form-layout-1{ padding:18px; }
	.single-trip .hh-half-itinerary__heading > div{ align-items:flex-start; flex-direction:column; gap:8px; }
	.single-trip .hh-half-itinerary__heading h2{ font-size:28px; }
	.single-trip .hh-half-itinerary__tabs{ grid-template-columns:1fr; }
	.single-trip .hh-half-itinerary__row{ padding-left:42px; }
	.single-trip .hh-half-itinerary__row::before{ left:5px; }
	.single-trip .hh-half-itinerary__row::after{ left:10px; }
	.single-trip .hh-half-itinerary__first-icon{ height:36px; left:-8px; top:22px; width:36px; }
	.single-trip .hh-half-itinerary__row.is-first::after{ top:58px; }
	.single-trip .hh-half-itinerary__row summary{ align-items:flex-start; flex-wrap:wrap; }
	.single-trip .hh-half-itinerary__time{ width:100%; }
	.single-trip .hh-half-itinerary__row summary strong::before{ content:""; }
	.single-trip .hh-half-itinerary__chevron{ margin-left:auto; position:absolute; right:0; top:31px; }
	.single-trip .hh-half-itinerary__content{ padding-right:8px; }
}
/* guard against accidental horizontal scroll from full-bleed sections */
.single-trip .hh-tp-cta,
.single-trip .hh-tp-trust{ overflow:hidden; }

/* ===================== OUR PACKAGES PAGE ===================== */
body.happy-herb-redesign.page-id-26 .site-main {
	background: #fffdf8;
}

body.happy-herb-redesign.page-id-26 #site-header {
	background: linear-gradient(180deg, rgba(13, 28, 12, 0.82), rgba(13, 28, 12, 0.14));
	border: 0;
	box-shadow: none;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

body.admin-bar.happy-herb-redesign.page-id-26 #site-header {
	top: 32px;
}

.hh-pkg-page {
	background: #fffdf8;
	color: var(--hh-ink);
	overflow: hidden;
}

.hh-pkg-hero {
	min-height: var(--hh-ref-hero-height);
}

.hh-pkg-hero::before {
	background-position: 55% 46%;
}

.hh-pkg-hero .hh-ref-hero__inner {
	min-height: var(--hh-ref-hero-height);
	padding-top: 120px;
}

.hh-pkg-hero .hh-ref-hero__copy {
	max-width: 760px;
}

.hh-pkg-hero .hh-ref-hero__shade {
	background:
		linear-gradient(90deg, rgba(8, 24, 12, 0.95) 0%, rgba(8, 24, 12, 0.79) 35%, rgba(8, 24, 12, 0.34) 66%, rgba(8, 24, 12, 0.08) 100%),
		linear-gradient(180deg, rgba(0, 0, 0, 0.24), rgba(0, 0, 0, 0.12) 55%, rgba(0, 0, 0, 0.64));
}

.hh-pkg-hero__eyebrow {
	color: #fffdf8;
	font-family: var(--hh-serif);
	font-size: clamp(25px, 2.4vw, 34px);
	font-weight: 500;
	line-height: 1;
	margin: 0 0 8px;
}

.hh-pkg-hero .hh-ref-hero__title {
	font-size: clamp(58px, 6vw, 80px);
	white-space: nowrap;
}

.hh-pkg-hero .hh-ref-hero__script {
	color: #efd28d;
	font-size: clamp(38px, 4vw, 52px);
	margin-top: 8px;
	white-space: nowrap;
}

.hh-pkg-hero__proof {
	max-width: min(1020px, calc(100vw - 84px));
}

.hh-pkg-heading {
	margin: 0 auto clamp(28px, 4vw, 44px);
	max-width: 820px;
	padding: 0 24px;
	text-align: center;
}

.hh-pkg-heading > span {
	color: var(--hh-moss);
	display: block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.16em;
	margin-bottom: 10px;
	text-transform: uppercase;
}

.hh-pkg-heading h2 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(34px, 4vw, 52px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0;
	text-wrap: balance;
}

.hh-pkg-heading p {
	color: var(--hh-muted);
	font-size: 15px;
	line-height: 1.65;
	margin: 12px auto 0;
	max-width: 680px;
}

.hh-pkg-benefits {
	background:
		radial-gradient(circle at 50% 0, rgba(201, 154, 69, 0.08), transparent 36%),
		#fffdf8;
	padding: clamp(52px, 6vw, 78px) 24px;
}

.hh-pkg-benefits__grid {
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	margin: 0 auto;
	max-width: 1200px;
}

.hh-pkg-benefit {
	padding: 8px 14px;
	text-align: center;
}

.hh-pkg-benefit__icon {
	align-items: center;
	background: rgba(201, 154, 69, 0.1);
	border: 1px solid rgba(201, 154, 69, 0.24);
	border-radius: 50%;
	color: var(--hh-moss);
	display: inline-flex;
	height: 58px;
	justify-content: center;
	margin-bottom: 14px;
	width: 58px;
}

.hh-pkg-benefit__icon svg,
.hh-pkg-card__icon svg,
.hh-pkg-included__item svg {
	fill: none;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 1.8;
}

.hh-pkg-benefit__icon svg {
	height: 30px;
	width: 30px;
}

.hh-pkg-benefit__icon svg[fill="currentColor"],
.hh-pkg-card__icon svg[fill="currentColor"],
.hh-pkg-included__item svg[fill="currentColor"] {
	fill: currentColor;
	stroke: none;
}

.hh-pkg-benefit h3 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.1;
	margin: 0 0 6px;
}

.hh-pkg-benefit p {
	color: var(--hh-muted);
	font-size: 12px;
	line-height: 1.45;
	margin: 0;
}

.hh-pkg-experiences {
	background:
		linear-gradient(180deg, rgba(239, 243, 228, 0.52), rgba(255, 253, 248, 0.96)),
		#eff3e4;
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	padding: clamp(58px, 7vw, 88px) 24px 56px;
	scroll-margin-top: 90px;
}

.hh-pkg-cards {
	display: grid;
	gap: 28px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin: 0 auto;
	max-width: 1180px;
}

.hh-pkg-card {
	background: #fff;
	border: 1px solid rgba(31, 78, 46, 0.14);
	border-radius: 10px;
	box-shadow: 0 18px 40px rgba(42, 55, 35, 0.11);
	display: flex;
	flex-direction: column;
	min-width: 0;
	overflow: hidden;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.hh-pkg-card:hover {
	box-shadow: 0 24px 50px rgba(42, 55, 35, 0.16);
	transform: translateY(-4px);
}

.hh-pkg-card--gold {
	border-color: rgba(201, 154, 69, 0.38);
}

.hh-pkg-card__media {
	aspect-ratio: 16 / 7.7;
	background: #d8dfc9;
	position: relative;
}

.hh-pkg-card__media::after {
	background: linear-gradient(180deg, rgba(8, 24, 12, 0.02), rgba(8, 24, 12, 0.3));
	content: "";
	inset: 0;
	position: absolute;
}

.hh-pkg-card__media img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.hh-pkg-card:nth-child(1) .hh-pkg-card__media img,
.hh-pkg-card:nth-child(2) .hh-pkg-card__media img,
.hh-pkg-card:nth-child(4) .hh-pkg-card__media img {
	object-position: center 36%;
}

.hh-pkg-card__badge {
	background: var(--hh-moss);
	border-radius: 5px;
	color: #fff;
	font-size: 10px;
	font-weight: 800;
	left: 16px;
	letter-spacing: 0.08em;
	padding: 7px 11px;
	position: absolute;
	text-transform: uppercase;
	top: 16px;
	z-index: 2;
}

.hh-pkg-card--gold .hh-pkg-card__badge {
	background: var(--hh-gold);
}

.hh-pkg-card__icon {
	align-items: center;
	background: #fffdf8;
	border: 1px solid rgba(31, 78, 46, 0.16);
	border-radius: 50%;
	bottom: -28px;
	box-shadow: 0 10px 22px rgba(42, 55, 35, 0.13);
	color: var(--hh-moss);
	display: flex;
	height: 58px;
	justify-content: center;
	left: 28px;
	position: absolute;
	width: 58px;
	z-index: 3;
}

.hh-pkg-card--gold .hh-pkg-card__icon {
	border-color: rgba(201, 154, 69, 0.42);
	color: var(--hh-gold);
}

.hh-pkg-card__icon svg {
	height: 29px;
	width: 29px;
}

.hh-pkg-card__body {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	padding: 42px 28px 26px;
}

.hh-pkg-card__body h3 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: clamp(26px, 2.4vw, 34px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.04;
	margin: 0 0 5px;
}

.hh-pkg-card__subtitle {
	color: var(--hh-moss);
	font-size: 13px;
	font-weight: 700;
	margin: 0 0 13px;
}

.hh-pkg-card--gold .hh-pkg-card__subtitle {
	color: #9f6e15;
}

.hh-pkg-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 18px;
	margin-bottom: 14px;
}

.hh-pkg-card__meta span {
	align-items: center;
	color: var(--hh-muted);
	display: inline-flex;
	font-size: 12px;
	font-weight: 600;
	gap: 6px;
}

.hh-pkg-card__meta svg {
	fill: none;
	height: 16px;
	stroke: var(--hh-moss);
	stroke-width: 1.8;
	width: 16px;
}

.hh-pkg-card__description {
	color: var(--hh-muted);
	font-size: 14px;
	line-height: 1.62;
	margin: 0 0 20px;
}

.hh-pkg-card__details {
	border-bottom: 1px solid rgba(31, 78, 46, 0.12);
	border-top: 1px solid rgba(31, 78, 46, 0.12);
	display: grid;
	gap: 22px;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	margin-bottom: 18px;
	padding: 18px 0;
}

.hh-pkg-card__details h4 {
	color: var(--hh-moss);
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 0.1em;
	margin: 0 0 10px;
	text-transform: uppercase;
}

.hh-pkg-card__perfect ul,
.hh-pkg-card__timeline ol {
	list-style: none;
	margin: 0;
	padding: 0;
}

.hh-pkg-card__perfect ul {
	display: grid;
	gap: 7px;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hh-pkg-card__perfect li {
	color: var(--hh-muted);
	font-size: 11px;
	line-height: 1.3;
	padding-left: 15px;
	position: relative;
}

.hh-pkg-card__perfect li::before {
	color: var(--hh-moss);
	content: "\2713";
	font-weight: 800;
	left: 0;
	position: absolute;
}

.hh-pkg-card__timeline ol {
	display: grid;
	gap: 6px;
	position: relative;
}

.hh-pkg-card__timeline ol::before {
	background: rgba(73, 111, 53, 0.24);
	bottom: 5px;
	content: "";
	left: 4px;
	position: absolute;
	top: 5px;
	width: 1px;
}

.hh-pkg-card__timeline li {
	color: var(--hh-muted);
	display: block;
	font-size: 11px;
	line-height: 1.3;
	padding-left: 14px;
	position: relative;
}

.hh-pkg-card__timeline li::before {
	background: #fff;
	border: 2px solid var(--hh-moss);
	border-radius: 50%;
	content: "";
	height: 7px;
	left: 1px;
	position: absolute;
	top: 4px;
	width: 7px;
}

.hh-pkg-card__timeline time {
	color: var(--hh-deep-2);
	display: block;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: -0.01em;
	margin-bottom: 2px;
}

.hh-pkg-card__price {
	margin-top: auto;
}

.hh-pkg-card__price p {
	align-items: baseline;
	display: flex;
	gap: 7px;
	margin: 0;
}

.hh-pkg-card__price strong {
	color: var(--hh-deep);
	font-family: var(--hh-serif);
	font-size: 34px;
	font-weight: 700;
	letter-spacing: -0.02em;
}

.hh-pkg-card__price p span {
	color: var(--hh-muted);
	font-size: 13px;
}

.hh-pkg-card__price small {
	color: var(--hh-muted);
	display: block;
	font-size: 11px;
	margin: 2px 0 14px;
}

.hh-pkg-card__book {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 6px;
	color: #fff !important;
	display: flex;
	font-size: 12px;
	font-weight: 800;
	justify-content: center;
	letter-spacing: 0.04em;
	min-height: 45px;
	padding: 12px 18px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-pkg-card--gold .hh-pkg-card__book {
	background: var(--hh-gold);
}

.hh-pkg-card__book:hover {
	background: var(--hh-deep-2);
}

.hh-pkg-dietary {
	align-items: center;
	color: var(--hh-muted);
	display: flex;
	font-size: 12px;
	gap: 8px;
	justify-content: center;
	line-height: 1.45;
	margin: 28px auto 0;
	max-width: 760px;
	text-align: center;
}

.hh-pkg-dietary svg {
	fill: none;
	flex: 0 0 auto;
	height: 18px;
	stroke: var(--hh-moss);
	stroke-width: 1.8;
	width: 18px;
}

.hh-pkg-included {
	background: #fffdf8;
	padding: clamp(58px, 7vw, 86px) 24px;
}

.hh-pkg-included__grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 0 auto;
	max-width: 1180px;
}

.hh-pkg-included__item {
	align-items: flex-start;
	background: rgba(239, 243, 228, 0.46);
	border: 1px solid rgba(31, 78, 46, 0.1);
	border-radius: 8px;
	display: grid;
	gap: 12px;
	grid-template-columns: 42px minmax(0, 1fr);
	padding: 18px;
}

.hh-pkg-included__item > span {
	align-items: center;
	background: var(--hh-deep-2);
	border-radius: 50%;
	color: #fff;
	display: flex;
	height: 42px;
	justify-content: center;
	width: 42px;
}

.hh-pkg-included__item svg {
	height: 21px;
	width: 21px;
}

.hh-pkg-included__item h3 {
	color: var(--hh-deep-2);
	font-family: var(--hh-serif);
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.1;
	margin: 0 0 5px;
}

.hh-pkg-included__item p {
	color: var(--hh-muted);
	font-size: 12px;
	line-height: 1.45;
	margin: 0;
}

.hh-pkg-compare {
	background:
		radial-gradient(circle at 0 100%, rgba(73, 111, 53, 0.16), transparent 34%),
		radial-gradient(circle at 100% 0, rgba(201, 154, 69, 0.14), transparent 30%),
		#f7f3e8;
	border-bottom: 1px solid rgba(31, 78, 46, 0.1);
	border-top: 1px solid rgba(31, 78, 46, 0.1);
	display: grid;
	gap: 28px;
	grid-template-columns: 250px minmax(0, 1fr);
	margin: 0 auto;
	max-width: 1320px;
	padding: 56px 36px;
}

.hh-pkg-compare__aside {
	align-self: stretch;
	background:
		linear-gradient(160deg, rgba(255, 255, 255, 0.08), transparent 45%),
		var(--hh-deep-2);
	border: 1px solid rgba(31, 78, 46, 0.18);
	border-radius: 16px;
	box-shadow: 0 18px 38px rgba(23, 49, 28, 0.13);
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 26px 22px;
}

.hh-pkg-compare__aside > span {
	color: #efd28d;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: 0.12em;
	margin-bottom: 9px;
	text-transform: uppercase;
}

.hh-pkg-compare__aside h2 {
	color: #fffdf8;
	font-family: var(--hh-serif);
	font-size: 28px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.05;
	margin: 0 0 12px;
}

.hh-pkg-compare__aside p {
	color: rgba(255, 253, 248, 0.78);
	font-size: 13px;
	line-height: 1.55;
	margin: 0 0 18px;
}

.hh-pkg-compare__aside a {
	align-items: center;
	align-self: flex-start;
	background: #efd28d;
	border-radius: 999px;
	color: var(--hh-deep-2) !important;
	display: inline-flex;
	font-size: 11px;
	font-weight: 800;
	min-height: 40px;
	padding: 10px 16px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-pkg-compare__aside a:hover {
	background: #fffdf8;
}

.hh-pkg-compare__table-wrap {
	background: #fffdf8;
	border: 1px solid rgba(31, 78, 46, 0.12);
	border-radius: 16px;
	box-shadow: 0 18px 42px rgba(23, 49, 28, 0.1);
	overflow-x: auto;
	position: relative;
	scrollbar-color: var(--hh-moss) #ece7d9;
	scrollbar-width: thin;
}

.hh-pkg-compare__scroll-note {
	background: var(--hh-deep-2);
	color: #fffdf8;
	display: none;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.03em;
	margin: 0;
	padding: 10px 16px;
	position: sticky;
	left: 0;
	text-align: center;
	width: 100%;
}

.hh-pkg-compare__table {
	border: 0;
	border-collapse: collapse;
	margin: 0;
	min-width: 960px;
	width: 100%;
}

.hh-pkg-compare__table th,
.hh-pkg-compare__table td {
	border: 0;
	border-bottom: 1px solid rgba(31, 78, 46, 0.09);
	border-right: 1px solid rgba(31, 78, 46, 0.08);
	font-size: 11.5px;
	line-height: 1.3;
	padding: 11px 7px;
	text-align: center;
}

.hh-pkg-compare__table th:last-child,
.hh-pkg-compare__table td:last-child {
	border-right: 0;
}

.hh-pkg-compare__table thead th {
	background: #efede5;
	color: var(--hh-deep-2);
	font-size: 11px;
	font-weight: 800;
	height: 92px;
	letter-spacing: 0.02em;
	position: relative;
	text-transform: uppercase;
	vertical-align: middle;
}

.hh-pkg-compare__table thead th:nth-child(2) {
	background: #eaf3de;
	box-shadow: inset 0 4px 0 #6f9d55;
}

.hh-pkg-compare__table thead th:nth-child(3) {
	background: #e8f1e0;
	box-shadow: inset 0 4px 0 #7fae63;
}

.hh-pkg-compare__table thead th:nth-child(4) {
	background: #fff0c9;
	box-shadow: inset 0 4px 0 #c99a45;
}

.hh-pkg-compare__table thead th:nth-child(5) {
	background: #e4f0dc;
	box-shadow: inset 0 4px 0 #496f35;
}

.hh-pkg-compare__table thead th:nth-child(6) {
	background: #e2eef0;
	box-shadow: inset 0 4px 0 #6a99a3;
}

.hh-pkg-compare__table thead th:nth-child(7) {
	background: #f4e2d4;
	box-shadow: inset 0 4px 0 #b8724d;
}

.hh-pkg-compare__name {
	display: block;
}

.hh-pkg-compare__table thead small {
	color: rgba(32, 53, 29, 0.68);
	display: block;
	font-size: 9px;
	font-weight: 700;
	letter-spacing: 0.04em;
	margin-top: 6px;
	text-transform: none;
}

.hh-pkg-compare__tag {
	background: var(--hh-gold);
	border-radius: 999px;
	color: #fff;
	display: inline-block;
	font-size: 8px;
	letter-spacing: 0.06em;
	margin-bottom: 7px;
	padding: 4px 8px;
}

.hh-pkg-compare__tag--new {
	background: var(--hh-moss);
}

.hh-pkg-compare__table thead th:first-child,
.hh-pkg-compare__table tbody th {
	text-align: left;
}

.hh-pkg-compare__table thead th:first-child {
	left: 0;
	position: sticky;
	z-index: 4;
}

.hh-pkg-compare__table tbody th {
	background: #fffdf8;
	color: var(--hh-deep-2);
	font-weight: 700;
	min-width: 152px;
	position: sticky;
	left: 0;
	z-index: 2;
}

.hh-pkg-compare__table td {
	color: var(--hh-muted);
}

.hh-pkg-compare__table tbody td:nth-child(2) {
	background: rgba(234, 243, 222, 0.42);
}

.hh-pkg-compare__table tbody td:nth-child(3) {
	background: rgba(232, 241, 224, 0.40);
}

.hh-pkg-compare__table tbody td:nth-child(4) {
	background: rgba(255, 240, 201, 0.38);
}

.hh-pkg-compare__table tbody td:nth-child(5) {
	background: rgba(228, 240, 220, 0.38);
}

.hh-pkg-compare__table tbody td:nth-child(6) {
	background: rgba(226, 238, 240, 0.36);
}

.hh-pkg-compare__table tbody td:nth-child(7) {
	background: rgba(244, 226, 212, 0.38);
}

.hh-pkg-compare__table tbody tr:hover th,
.hh-pkg-compare__table tbody tr:hover td {
	filter: brightness(0.98);
}

.hh-pkg-compare__table .is-yes {
	color: var(--hh-moss);
	font-weight: 800;
}

.hh-pkg-compare__table .is-yes::before {
	align-items: center;
	background: var(--hh-moss);
	border-radius: 999px;
	color: #fff;
	content: "\2713";
	display: inline-flex;
	font-size: 10px;
	height: 20px;
	justify-content: center;
	margin-right: 6px;
	width: 20px;
}

.hh-pkg-compare__table .is-age {
	color: #8a4c2e;
	font-weight: 800;
}

.hh-pkg-compare__table .is-duration th {
	background: var(--hh-deep-2);
	color: #fffdf8;
	font-weight: 700;
}

.hh-pkg-compare__table .is-duration td {
	color: var(--hh-deep-2);
	font-weight: 800;
}

.hh-pkg-reviews {
	background:
		radial-gradient(circle at 50% 0, rgba(201, 154, 69, 0.08), transparent 34%),
		#fffdf8;
}

.hh-pkg-cta {
	align-items: stretch;
	background: var(--hh-deep-2);
	color: #fff;
	display: grid;
	grid-template-columns: minmax(280px, 0.85fr) minmax(390px, 1.1fr) minmax(220px, 0.65fr);
	margin: 0 auto;
	max-width: 1440px;
	min-height: 260px;
	overflow: hidden;
}

.hh-pkg-cta figure {
	margin: 0;
	min-height: 260px;
	position: relative;
}

.hh-pkg-cta figure::after {
	background: linear-gradient(90deg, transparent 58%, var(--hh-deep-2));
	content: "";
	inset: 0;
	position: absolute;
}

.hh-pkg-cta figure img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.hh-pkg-cta__copy {
	align-self: center;
	padding: 38px 28px;
}

.hh-pkg-cta__copy > p {
	color: #efd28d;
	font-family: var(--hh-script);
	font-size: 25px;
	line-height: 1;
	margin: 0 0 7px;
}

.hh-pkg-cta__copy h2 {
	color: #fff;
	font-family: var(--hh-serif);
	font-size: clamp(34px, 3.4vw, 48px);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1;
	margin: 0 0 10px;
}

.hh-pkg-cta__copy > span {
	color: rgba(255, 255, 255, 0.76);
	display: block;
	font-size: 14px;
	line-height: 1.5;
}

.hh-pkg-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 20px;
}

.hh-pkg-cta__actions a {
	align-items: center;
	border-radius: 6px;
	display: inline-flex;
	font-size: 11px;
	font-weight: 800;
	gap: 7px;
	justify-content: center;
	min-height: 43px;
	padding: 11px 16px;
	text-decoration: none !important;
	text-transform: uppercase;
}

.hh-pkg-cta__book {
	background: var(--hh-gold);
	color: #fff !important;
}

.hh-pkg-cta__wa {
	border: 1px solid rgba(255, 255, 255, 0.62);
	color: #fff !important;
}

.hh-pkg-cta__wa svg {
	fill: currentColor;
	height: 18px;
	width: 18px;
}

.hh-pkg-cta > ul {
	align-self: center;
	display: grid;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 32px 34px 32px 10px;
}

.hh-pkg-cta > ul li {
	color: rgba(255, 255, 255, 0.86);
	font-size: 13px;
	line-height: 1.3;
	padding-left: 20px;
	position: relative;
}

.hh-pkg-cta > ul li::before {
	color: #efd28d;
	content: "\2713";
	font-weight: 800;
	left: 0;
	position: absolute;
}

@media (max-width: 1100px) {
	.hh-pkg-hero__proof {
		display: grid;
		grid-template-columns: repeat(3, minmax(0, 1fr));
		width: min(720px, calc(100vw - 64px));
	}

	.hh-pkg-hero__proof .hh-ref-hero__proof-item {
		border: 0;
		padding: 7px 14px 7px 0;
	}

	.hh-pkg-benefits__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		row-gap: 28px;
	}

	.hh-pkg-included__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-pkg-cta {
		grid-template-columns: 0.8fr 1.2fr;
	}

	.hh-pkg-cta > ul {
		display: none;
	}
}

@media (max-width: 860px) {
	.hh-pkg-cards {
		grid-template-columns: 1fr;
		max-width: 620px;
	}

	.hh-pkg-card__body h3 {
		font-size: 32px;
	}

	.hh-pkg-compare {
		grid-template-columns: 1fr;
		padding-inline: 24px;
	}

	.hh-pkg-compare__aside {
		align-items: center;
		text-align: center;
	}

	.hh-pkg-compare__aside a {
		align-self: center;
	}
}

@media (max-width: 720px) {
	body.admin-bar.happy-herb-redesign.page-id-26 #site-header {
		top: 46px;
	}

	.hh-pkg-hero,
	.hh-pkg-hero .hh-ref-hero__inner {
		min-height: var(--hh-ref-hero-height);
	}

	.hh-pkg-hero::before {
		background-position: 64% center;
	}

	.hh-pkg-hero .hh-ref-hero__shade {
		background: linear-gradient(180deg, rgba(8, 24, 12, 0.48), rgba(8, 24, 12, 0.88) 60%, rgba(8, 24, 12, 0.98));
	}

	.hh-pkg-hero .hh-ref-hero__inner {
		align-items: center;
		padding: 76px 20px 24px;
	}

	.hh-pkg-hero .hh-ref-hero__title {
		font-size: 54px;
		white-space: normal;
	}

	.hh-pkg-hero .hh-ref-hero__script {
		font-size: 37px;
		white-space: normal;
	}

	.hh-pkg-hero__proof {
		gap: 2px 10px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 22px;
		max-width: none;
		width: 100%;
	}

	.hh-pkg-hero__proof .hh-ref-hero__proof-item {
		min-width: 0;
	}

	.hh-pkg-hero__proof .hh-ref-hero__proof-icon {
		height: 28px;
		width: 28px;
	}

	.hh-pkg-hero__proof .hh-ref-hero__proof-copy {
		white-space: normal;
	}

	.hh-pkg-benefits,
	.hh-pkg-experiences,
	.hh-pkg-included {
		padding-inline: 18px;
	}

	.hh-pkg-benefits__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hh-pkg-benefit {
		padding-inline: 8px;
	}

	.hh-pkg-card__media {
		aspect-ratio: 16 / 9;
	}

	.hh-pkg-card__body {
		padding: 40px 20px 22px;
	}

	.hh-pkg-card__details {
		grid-template-columns: 1fr;
	}

	.hh-pkg-included__grid {
		grid-template-columns: 1fr;
	}

	.hh-pkg-cta {
		display: block;
	}

	.hh-pkg-cta figure {
		height: 220px;
		min-height: 0;
	}

	.hh-pkg-cta figure::after {
		background: linear-gradient(180deg, transparent 48%, var(--hh-deep-2));
	}

	.hh-pkg-cta__copy {
		padding: 4px 20px 32px;
		text-align: center;
	}

	.hh-pkg-cta__actions {
		flex-direction: column;
	}

	.hh-pkg-cta__actions a {
		width: 100%;
	}
}

@media (max-width: 440px) {
	.hh-pkg-hero .hh-ref-hero__title {
		font-size: 48px;
	}

	.hh-pkg-hero__proof .hh-ref-hero__proof-copy span {
		display: none;
	}

	.hh-pkg-heading h2 {
		font-size: 34px;
	}

	.hh-pkg-benefit h3 {
		font-size: 16px;
	}

	.hh-pkg-card__perfect ul {
		grid-template-columns: 1fr;
	}
}

/* ===================== OUR STORY TYPOGRAPHY REFINEMENTS ===================== */
body.happy-herb-redesign.hh-our-story-page .hh-story-kicker,
body.happy-herb-redesign.hh-our-story-page .hh-story-heading > span,
body.happy-herb-redesign.hh-our-story-page .hh-story-video__copy > span {
	color: #c99a45;
	font-family: "Dancing Script", "Segoe Script", "Brush Script MT", cursive;
	font-size: 34px;
	font-weight: 500;
	line-height: 1;
	margin: 0 0 8px;
}

body.happy-herb-redesign.hh-our-story-page .hh-story-founder__copy p,
body.happy-herb-redesign.hh-our-story-page .hh-story-timeline__card p,
body.happy-herb-redesign.hh-our-story-page .hh-story-video__copy p {
	color: #5f6b62;
	font-family: "DM Sans", "Helvetica Neue", Arial, sans-serif;
	font-size: 15px;
	line-height: 1.7;
	margin: 0 0 24px;
}

body.happy-herb-redesign.hh-our-story-page .hh-story-belief p {
	color: #5f6b62;
	font-family: "DM Sans", "Helvetica Neue", Arial, sans-serif;
	font-size: 12px;
	line-height: 1.55;
	margin: 0;
}

body.happy-herb-redesign.hh-our-story-page .hh-story-timeline__card h3,
body.happy-herb-redesign.hh-our-story-page .hh-story-belief h3,
body.happy-herb-redesign.hh-our-story-page .hh-story-love__item strong {
	color: #132312;
	font-family: "DM Sans", "Helvetica Neue", Arial, sans-serif;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.45;
}

body.happy-herb-redesign.hh-our-story-page .hh-story-video__button {
	align-items: center;
	background: #496f35;
	border-color: #496f35;
	color: #fff;
	display: inline-flex;
	font-family: "DM Sans", "Helvetica Neue", Arial, sans-serif;
	font-size: 14px;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0;
	line-height: 1.1;
	min-height: 52px;
	min-width: 204px;
	padding: 15px 22px;
	text-transform: none;
}

body.happy-herb-redesign.hh-our-story-page .hh-story-text-link,
body.happy-herb-redesign.hh-our-story-page .hh-story-timeline__year {
	font-size: 16px;
}

/* Keep all primary page heroes aligned to the Home hero height. */
@media (max-width: 959px) {
	.hh-story-hero .hh-ref-hero__inner,
	.hh-pkg-hero .hh-ref-hero__inner,
	.hh-farm-hero .hh-ref-hero__inner,
	.hh-ct-contact-hero .hh-ref-hero__inner {
		padding-top: 86px;
		padding-bottom: 32px;
	}
}

@media (max-width: 767px) {
	.hh-story-hero,
	.hh-story-hero .hh-ref-hero__inner,
	.hh-pkg-hero,
	.hh-pkg-hero .hh-ref-hero__inner,
	.hh-farm-hero,
	.hh-farm-hero .hh-ref-hero__inner,
	.hh-ct-contact-hero,
	.hh-ct-contact-hero .hh-ref-hero__inner {
		min-height: var(--hh-ref-hero-height);
	}

	.hh-story-hero .hh-ref-hero__inner,
	.hh-pkg-hero .hh-ref-hero__inner,
	.hh-farm-hero .hh-ref-hero__inner,
	.hh-ct-contact-hero .hh-ref-hero__inner {
		align-items: center;
		padding: 64px 20px 20px;
	}

	.hh-story-hero .hh-ref-hero__title,
	.hh-pkg-hero .hh-ref-hero__title,
	.hh-farm-hero .hh-ref-hero__title,
	.hh-ct-contact-hero .hh-ref-hero__title {
		font-size: clamp(35px, 10vw, 46px);
		line-height: 1.02;
		white-space: normal;
	}

	.hh-pkg-hero__eyebrow {
		font-size: 20px;
		margin-bottom: 5px;
	}

	.hh-story-hero .hh-ref-hero__script,
	.hh-pkg-hero .hh-ref-hero__script,
	.hh-farm-hero .hh-ref-hero__script,
	.hh-ct-contact-hero .hh-ref-hero__script {
		font-size: 28px;
		margin: 8px 0 12px;
	}

	.hh-story-hero .hh-ref-hero__text,
	.hh-pkg-hero .hh-ref-hero__text,
	.hh-farm-hero .hh-ref-hero__text,
	.hh-ct-contact-hero .hh-ref-hero__text {
		font-size: 14px;
		line-height: 1.45;
	}

	.hh-story-hero .hh-ref-hero__actions,
	.hh-pkg-hero .hh-ref-hero__actions,
	.hh-ct-contact-hero .hh-ref-hero__actions {
		display: grid;
		gap: 8px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 16px;
	}

	.hh-story-hero .hh-ref-button,
	.hh-pkg-hero .hh-ref-button,
	.hh-ct-contact-hero .hh-ref-button {
		font-size: 12px;
		min-height: 44px;
		min-width: 0;
		padding: 10px 8px;
		width: 100%;
	}

	.hh-story-hero .hh-ref-hero__proof,
	.hh-pkg-hero .hh-ref-hero__proof,
	.hh-farm-hero .hh-ref-hero__proof,
	.hh-ct-contact-hero .hh-ref-hero__proof {
		display: grid;
		gap: 0;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 14px;
		max-width: none;
		width: 100%;
	}

	.hh-story-hero .hh-ref-hero__proof-item,
	.hh-pkg-hero .hh-ref-hero__proof-item,
	.hh-farm-hero .hh-ref-hero__proof-item,
	.hh-ct-contact-hero .hh-ref-hero__proof-item {
		border-bottom: 1px solid rgba(255, 255, 255, 0.2);
		border-right: 0;
		gap: 7px;
		min-height: 38px;
		min-width: 0;
		padding: 6px 8px;
		width: auto;
	}

	.hh-story-hero .hh-ref-hero__proof-item:nth-child(odd),
	.hh-pkg-hero .hh-ref-hero__proof-item:nth-child(odd),
	.hh-farm-hero .hh-ref-hero__proof-item:nth-child(odd),
	.hh-ct-contact-hero .hh-ref-hero__proof-item:nth-child(odd) {
		border-right: 1px solid rgba(255, 255, 255, 0.2);
	}

	.hh-story-hero .hh-ref-hero__proof-icon,
	.hh-pkg-hero .hh-ref-hero__proof-icon,
	.hh-farm-hero .hh-ref-hero__proof-icon,
	.hh-ct-contact-hero .hh-ref-hero__proof-icon {
		height: 24px;
		width: 24px;
	}

	.hh-story-hero .hh-ref-hero__proof-copy,
	.hh-pkg-hero .hh-ref-hero__proof-copy,
	.hh-farm-hero .hh-ref-hero__proof-copy,
	.hh-ct-contact-hero .hh-ref-hero__proof-copy {
		white-space: normal;
	}

	.hh-story-hero .hh-ref-hero__proof-copy strong,
	.hh-pkg-hero .hh-ref-hero__proof-copy strong,
	.hh-farm-hero .hh-ref-hero__proof-copy strong,
	.hh-ct-contact-hero .hh-ref-hero__proof-copy strong {
		font-size: 11px;
		line-height: 1.2;
	}

	.hh-story-hero .hh-ref-hero__proof-copy span,
	.hh-pkg-hero .hh-ref-hero__proof-copy span,
	.hh-farm-hero .hh-ref-hero__proof-copy span,
	.hh-ct-contact-hero .hh-ref-hero__proof-copy span {
		display: none;
	}

	.hh-pkg-compare__scroll-note {
		display: block;
	}
}

/* Footer work-with-us column. */
@media (min-width: 1181px) {
	.hh-ref-footer-main__inner {
		grid-template-columns: minmax(210px, .95fr) minmax(118px, .54fr) minmax(138px, .62fr) minmax(170px, .72fr) minmax(280px, 1.18fr);
	}
}

.hh-ref-footer-work {
	border-left: 1px solid rgba(31, 78, 46, .12);
	padding-left: clamp(16px, 2vw, 28px);
}

@media (max-width: 900px) {
	.hh-ref-footer-work {
		border-left: 0;
		padding-left: 0;
	}
}

/* Primary-page header and hero consistency. */
body.happy-herb-redesign.hh-ref-header-dark:is(
	.home,
	.page-id-11,
	.hh-our-story-page,
	.page-id-26,
	.page-id-20,
	.hh-ref-farm-updates-page,
	.hh-partners-page,
	.page-id-22
) {
	--hh-primary-hero-height: clamp(560px, 72vh, 700px);
}

body.happy-herb-redesign.hh-ref-header-dark:is(
	.home,
	.page-id-11,
	.hh-our-story-page,
	.page-id-26,
	.page-id-20,
	.hh-ref-farm-updates-page,
	.hh-partners-page,
	.page-id-22
) #site-header {
	background: linear-gradient(180deg, rgba(13, 28, 12, 0.78), rgba(13, 28, 12, 0.2)) !important;
	border: 0 !important;
	box-shadow: none !important;
	inset: 0 0 auto;
	position: absolute !important;
	z-index: 1000;
}

body.admin-bar.happy-herb-redesign.hh-ref-header-dark:is(
	.home,
	.page-id-11,
	.hh-our-story-page,
	.page-id-26,
	.page-id-20,
	.hh-ref-farm-updates-page,
	.hh-partners-page,
	.page-id-22
) #site-header {
	top: 32px;
}

body.happy-herb-redesign.hh-ref-header-dark:is(
	.home,
	.page-id-11,
	.hh-our-story-page,
	.page-id-26,
	.page-id-20,
	.hh-ref-farm-updates-page,
	.hh-partners-page,
	.page-id-22
) .hh-ref-hero {
	--hh-ref-hero-height: var(--hh-primary-hero-height);
	min-height: var(--hh-primary-hero-height);
}

body.happy-herb-redesign.hh-ref-header-dark:is(
	.home,
	.page-id-11,
	.hh-our-story-page,
	.page-id-26,
	.page-id-20,
	.hh-ref-farm-updates-page,
	.hh-partners-page,
	.page-id-22
) .hh-ref-hero .hh-ref-hero__inner {
	min-height: var(--hh-primary-hero-height);
}

body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element.elementor-element-hhga1230 {
	--align-items: center;
	--justify-content: center;
	--min-height: var(--hh-primary-hero-height);
	--padding-top: 104px;
	--padding-right: 42px;
	--padding-bottom: 48px;
	--padding-left: 42px;
	background:
		linear-gradient(90deg, rgba(11, 25, 10, 0.88), rgba(11, 25, 10, 0.48)),
		url("/wp-content/uploads/2026/02/DSCF8278-1.jpg") center 48% / cover no-repeat !important;
	color: var(--hh-white);
	isolation: isolate;
	min-height: var(--hh-primary-hero-height);
	overflow: hidden;
}

body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element-hhga1230 > .e-con-inner {
	align-content: center;
	justify-content: center;
	min-height: calc(var(--hh-primary-hero-height) - 152px);
}

body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element-hhga1231 .elementor-heading-title {
	color: var(--hh-white);
	font-family: var(--hh-serif);
	font-size: clamp(42px, 4.8vw, 66px);
	font-weight: 600;
	line-height: 1.03;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.36);
}

body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element-hhga1232 .elementor-heading-title {
	color: #f2ddb1;
	font-family: var(--hh-script);
	font-size: clamp(34px, 3.8vw, 50px);
	font-weight: 500;
	line-height: 1;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.28);
}

@media (max-width: 959px) {
	body.happy-herb-redesign.hh-ref-header-dark:is(
		.home,
		.page-id-11,
		.hh-our-story-page,
		.page-id-26,
		.page-id-20,
		.hh-ref-farm-updates-page,
		.hh-partners-page,
		.page-id-22
	) {
		--hh-primary-hero-height: 560px;
	}

	body.happy-herb-redesign.hh-ref-header-dark:is(
		.home,
		.page-id-11,
		.hh-our-story-page,
		.page-id-26,
		.page-id-20,
		.hh-ref-farm-updates-page,
		.hh-partners-page,
		.page-id-22
	) #site-header {
		background: rgba(19, 35, 18, 0.98) !important;
		inset: auto;
		position: sticky !important;
		top: 0 !important;
	}

	body.admin-bar.happy-herb-redesign.hh-ref-header-dark:is(
		.home,
		.page-id-11,
		.hh-our-story-page,
		.page-id-26,
		.page-id-20,
		.hh-ref-farm-updates-page,
		.hh-partners-page,
		.page-id-22
	) #site-header {
		top: 32px !important;
	}

	body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element.elementor-element-hhga1230 {
		--padding-top: 86px;
		--padding-right: 28px;
		--padding-bottom: 42px;
		--padding-left: 28px;
	}

	body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element-hhga1230 > .e-con-inner {
		min-height: calc(var(--hh-primary-hero-height) - 128px);
	}

	body.hh-partners-page .hh-partner-hero .hh-ref-hero__inner {
		padding-bottom: 42px;
		padding-top: 86px;
	}
}

@media (max-width: 782px) {
	body.admin-bar.happy-herb-redesign.hh-ref-header-dark:is(
		.home,
		.page-id-11,
		.hh-our-story-page,
		.page-id-26,
		.page-id-20,
		.hh-ref-farm-updates-page,
		.hh-partners-page,
		.page-id-22
	) #site-header {
		top: 46px !important;
	}
}

@media (max-width: 767px) {
	body.happy-herb-redesign.hh-ref-header-dark:is(
		.home,
		.page-id-11,
		.hh-our-story-page,
		.page-id-26,
		.page-id-20,
		.hh-ref-farm-updates-page,
		.hh-partners-page,
		.page-id-22
	) {
		--hh-primary-hero-height: 520px;
	}

	body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element.elementor-element-hhga1230 {
		--padding-top: 76px;
		--padding-right: 20px;
		--padding-bottom: 34px;
		--padding-left: 20px;
	}

	body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element-hhga1230 > .e-con-inner {
		min-height: calc(var(--hh-primary-hero-height) - 110px);
	}

	body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element-hhga1231 .elementor-heading-title {
		font-size: clamp(36px, 10vw, 48px);
	}

	body.happy-herb-redesign.page-id-20 .elementor-20 .elementor-element-hhga1232 .elementor-heading-title {
		font-size: 30px;
	}

	body.hh-partners-page .hh-partner-hero .hh-ref-hero__inner {
		align-items: center;
		padding: 64px 20px 20px;
	}

	body.hh-partners-page .hh-partner-hero .hh-ref-hero__title {
		font-size: clamp(35px, 10vw, 46px);
		line-height: 1.02;
	}

	body.hh-partners-page .hh-partner-hero .hh-ref-hero__text {
		font-size: 14px;
		line-height: 1.45;
	}

	body.hh-partners-page .hh-partner-hero .hh-ref-hero__actions {
		display: grid;
		gap: 8px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 16px;
	}

	body.hh-partners-page .hh-partner-hero .hh-ref-button {
		font-size: 12px;
		min-height: 44px;
		min-width: 0;
		padding: 10px 8px;
		width: 100%;
	}

	body.hh-partners-page .hh-partner-hero__proof {
		display: grid;
		gap: 0;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		margin-top: 14px;
		max-width: none;
		width: 100%;
	}

	body.hh-partners-page .hh-partner-hero__proof .hh-ref-hero__proof-item {
		border-bottom: 1px solid rgba(255, 255, 255, 0.2);
		border-right: 1px solid rgba(255, 255, 255, 0.2);
		gap: 7px;
		min-height: 38px;
		min-width: 0;
		padding: 6px 8px;
		width: auto;
	}

	body.hh-partners-page .hh-partner-hero__proof .hh-ref-hero__proof-item:nth-child(2),
	body.hh-partners-page .hh-partner-hero__proof .hh-ref-hero__proof-item:last-child {
		border-right: 0;
	}

	body.hh-partners-page .hh-partner-hero__proof .hh-ref-hero__proof-item:last-child {
		grid-column: 1 / -1;
	}

	body.hh-partners-page .hh-partner-hero__proof .hh-ref-hero__proof-copy {
		white-space: normal;
	}

	body.hh-partners-page .hh-partner-hero__proof .hh-ref-hero__proof-copy strong {
		font-size: 11px;
		line-height: 1.2;
	}

	body.hh-partners-page .hh-partner-hero__proof .hh-ref-hero__proof-copy span {
		display: none;
	}
}

/* ============================================================================
 * Amelia booking pop-up on single trip pages (Check Availability → modal).
 * See inc/hh-amelia-trip-booking.php. Branded to the Happy Herb palette.
 * ========================================================================== */
.hh-amelia-modal { display: none; }
body.hh-amelia-modal-lock { overflow: hidden; }
.hh-amelia-modal.is-open {
	display: flex;
	position: fixed;
	inset: 0;
	z-index: 100000;
	background: rgba(22, 35, 27, 0.62);
	backdrop-filter: blur(2px);
	align-items: flex-start;
	justify-content: center;
	padding: 4vh 16px;
	overflow-y: auto;
}
.hh-amelia-modal__dialog {
	position: relative;
	width: 100%;
	max-width: 960px;
	background: var(--hh-paper, #fffdf8);
	border-radius: 16px;
	box-shadow: 0 30px 90px rgba(0, 0, 0, 0.38);
	overflow: hidden;
	animation: hhAmeliaPop 0.22s ease-out;
}
@keyframes hhAmeliaPop { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.hh-amelia-modal__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 22px;
	background: linear-gradient(135deg, var(--hh-forest, #1f4e2e), var(--hh-moss, #496f35));
	color: #fff;
}
.hh-amelia-modal__eyebrow {
	display: block;
	font-family: var(--hh-sans, sans-serif);
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--hh-sun, #f2c14e);
	margin-bottom: 4px;
}
.hh-amelia-modal__title {
	margin: 0;
	font-family: var(--hh-serif, serif);
	font-size: 1.5rem;
	line-height: 1.2;
	color: #fff;
}
.hh-amelia-modal__close {
	flex: 0 0 auto;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	border: 0;
	background: rgba(255, 255, 255, 0.16);
	color: #fff;
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	transition: background 0.15s ease;
}
.hh-amelia-modal__close:hover { background: rgba(255, 255, 255, 0.3); }
.hh-amelia-modal__body { padding: 6px 10px 14px; max-height: calc(92vh - 84px); overflow-y: auto; }
.hh-amelia-open-proxy { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; pointer-events: none; }

/* Brand the Amelia form to the Happy Herb palette (Amelia's default is blue).
 * Amelia paints concrete colours, so target the elements directly. */
/* Step sidebar → forest. */
.hh-amelia-modal .am-fs-sb { background-color: #1f4e2e !important; }
.hh-amelia-modal .am-fs-sb .am-fss-nav__item.am-active,
.hh-amelia-modal .am-fs-sb [class*="nav"][class*="active"] { background-color: rgba(255, 255, 255, 0.12) !important; }
/* Primary buttons (Continue, Finish, etc.) → forest. */
.hh-amelia-modal .am-button--primary,
.hh-amelia-modal .am-button--filled.am-button--default {
	background-color: #1f4e2e !important;
	border-color: #1f4e2e !important;
	color: #fff !important;
}
.hh-amelia-modal .am-button--primary:hover,
.hh-amelia-modal .am-button--filled.am-button--default:hover {
	background-color: #163c24 !important;
	border-color: #163c24 !important;
}

/* Half-Day named session slots (Morning / Afternoon) in the Amelia pop-up. */
.hh-amelia-modal .hh-am-slot-name { display: block; font-weight: 700; line-height: 1.2; }
.hh-amelia-modal .hh-am-slot-time { display: block; font-size: 0.82em; opacity: 0.82; margin-top: 2px; }

/* ============================================================================
 * Standalone Trip Pages (theme template, no WP Travel Engine).
 * See inc/hh-trip-pages.php + templates/hh-trip-page.php.
 * ========================================================================== */
body.hh-trip-tpl .page-header,
body.hh-trip-tpl #site-header-inner .page-header,
body.hh-trip-tpl .single-page-title,
body.hh-trip-tpl .oceanwp-breadcrumb,
body.hh-trip-tpl #breadcrumb { display: none !important; }
.hh-trip-page .hh-trip-layout {
	max-width: var(--hh-max, 1120px);
	margin: 0 auto;
	padding: 48px 20px;
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 40px;
	align-items: start;
}
.hh-trip-main { min-width: 0; }
.hh-trip-aside { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 18px; }
.hh-trip-aside__card {
	background: var(--hh-white, #fff);
	border: 1px solid var(--hh-line, #d8ded7);
	border-radius: 14px;
	padding: 22px;
	box-shadow: var(--hh-shadow, 0 14px 34px rgba(22,35,27,0.12));
}
.hh-trip-aside__from { margin: 0; color: var(--hh-clay, #b4753f); font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; }
.hh-trip-aside__price { margin: 4px 0 16px; font-family: var(--hh-serif, serif); font-size: 2rem; line-height: 1.1; color: var(--hh-forest, #1f4e2e); font-weight: 700; }
.hh-trip-aside__price span { font-size: 0.9rem; color: var(--hh-muted, #5f6b62); font-family: var(--hh-sans, sans-serif); font-weight: 500; }
.hh-trip-aside__btn {
	display: block; width: 100%; border: 0; cursor: pointer;
	background: var(--hh-forest, #1f4e2e); color: #fff;
	font-family: var(--hh-sans, sans-serif); font-weight: 700; font-size: 1rem;
	letter-spacing: 0.04em; text-transform: uppercase; padding: 15px; border-radius: 10px;
	transition: background 0.15s ease;
}
.hh-trip-aside__btn:hover { background: #163c24; }
.hh-trip-aside__help { margin: 12px 0 0; text-align: center; font-size: 0.82rem; color: var(--hh-muted, #5f6b62); }
.hh-trip-aside__help a { color: var(--hh-forest, #1f4e2e); font-weight: 600; }
@media ( max-width: 980px ) {
	.hh-trip-page .hh-trip-layout { grid-template-columns: 1fr; gap: 28px; padding: 28px 16px; }
	.hh-trip-aside { position: static; }
}

/* Ensure itinerary rows clear the timeline icon/dot (first-row time was hidden under the pin). */
.single-trip .hh-half-itinerary__panel .hh-half-itinerary__row { padding-left: 64px !important; }
.single-trip .hh-half-itinerary__panel .hh-half-itinerary__row summary { padding-left: 0; }
.single-trip .hh-half-itinerary__row.is-first summary { padding-left: 56px; }
/* Center the first-row itinerary pin on the timeline line (was offset right). */
.single-trip .hh-half-itinerary__row.is-first summary { padding-left: 0; }
.single-trip .hh-half-itinerary__row.is-first .hh-half-itinerary__first-icon { left: -65px; }

/* ============================================================
   Theme-native Trip Enquiry form (.hh-tp-enquiry)
   Replaces the retired WP Travel Engine enquiry form.
   ============================================================ */
.hh-tp-enquiry{ background:#fbf9f3; padding:60px 20px; }
.hh-tp-enquiry__inner{ max-width:1040px; margin:0 auto; }
.hh-tp-enquiry .hh-tp-section-head{ text-align:center; margin-bottom:14px; }
.hh-tp-enquiry__intro{ background:#f7f2e7; border-left:4px solid #c9973f; color:#46503c; font-size:16px; line-height:1.65; margin:0 auto 26px; padding:15px 18px; max-width:840px; border-radius:4px; }
.hh-tp-enquiry__intro a{ color:#496f35; font-weight:700; }
.hh-tp-enquiry__notice{ border-radius:6px; font-size:15px; line-height:1.5; margin:0 auto 22px; padding:14px 18px; max-width:840px; }
.hh-tp-enquiry__notice--ok{ background:#e7f3e3; border:1px solid #8bbf7a; color:#234d18; }
.hh-tp-enquiry__notice--err{ background:#fbeaea; border:1px solid #d99; color:#7a1f1f; }
.hh-tp-enquiry__form{ background:#fff; border:1px solid #e6e1d2; border-radius:12px; padding:30px 28px; box-shadow:0 10px 30px rgba(32,53,29,.06); }
.hh-tp-enquiry .hh-hp{ position:absolute !important; left:-9999px !important; height:0; overflow:hidden; }
.hh-enq-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px 20px; }
.hh-enq-field{ margin:0; display:flex; flex-direction:column; }
.hh-enq-field--full{ grid-column:1 / -1; }
.hh-tp-enquiry .hh-enq-field--full{ grid-column:auto; }
.hh-tp-enquiry__form > .hh-enq-field--full{ grid-column:auto; }
.hh-enq-field label,
.hh-enq-dietary legend{ color:#20351d; font-weight:600; font-size:14px; margin-bottom:6px; }
.hh-enq-field label span{ color:#c0392b; }
.hh-tp-enquiry input[type=text],
.hh-tp-enquiry input[type=email],
.hh-tp-enquiry input[type=number],
.hh-tp-enquiry input[type=date],
.hh-tp-enquiry select,
.hh-tp-enquiry textarea{ width:100%; border:1px solid #cfc9b8; border-radius:8px; padding:11px 13px; font-size:15px; color:#2c3526; background:#fff; font-family:inherit; }
.hh-tp-enquiry input:focus,
.hh-tp-enquiry select:focus,
.hh-tp-enquiry textarea:focus{ outline:none; border-color:#496f35; box-shadow:0 0 0 3px rgba(73,111,53,.15); }
.hh-enq-note{ color:#6b7263; font-size:13px; line-height:1.4; margin-top:6px; }
.hh-enq-dietary{ border:0; margin:20px 0 4px; padding:0; }
.hh-enq-dietary legend{ padding:0; }
.hh-enq-check{ display:inline-flex; align-items:center; gap:8px; margin:0 18px 10px 0; font-size:15px; color:#3a4233; font-weight:400; }
.hh-enq-check input{ width:auto; }
.hh-enq-consent{ margin:20px 0 8px; font-size:14px; color:#46503c; }
.hh-enq-consent label{ display:flex; align-items:flex-start; gap:9px; }
.hh-enq-consent input{ margin-top:3px; }
.hh-enq-consent a{ color:#496f35; font-weight:600; }
.hh-enq-submit{ margin:8px 0 0; }
.hh-tp-enquiry .hh-enq-submit .hh-tp-cta__btn{ border:0; cursor:pointer; font-size:16px; }
@media (max-width:700px){
	.hh-enq-grid{ grid-template-columns:1fr; }
	.hh-tp-enquiry{ padding:44px 16px; }
	.hh-tp-enquiry__form{ padding:22px 18px; }
}


/* What Sets Us Apart - journey style */
.hh-ref-journey {
	background:
		radial-gradient(circle at 7% 12%, rgba(201, 154, 69, 0.14), transparent 24%),
		radial-gradient(circle at 91% 12%, rgba(31, 78, 46, 0.09), transparent 26%),
		linear-gradient(180deg, #faf4eb 0%, var(--hh-cream) 100%);
	overflow: hidden;
	padding: 88px 24px 92px;
	position: relative;
}

.hh-ref-journey__head {
	margin: 0 auto 48px;
	max-width: 860px;
	position: relative;
	text-align: center;
	z-index: 1;
}

.hh-ref-journey__eyebrow {
	color: var(--hh-gold);
	font-family: var(--hh-serif);
	font-size: 22px;
	font-style: italic;
	margin: 0 0 8px;
}

.hh-ref-journey__head h2 {
	color: #20351d;
	font-family: var(--hh-serif);
	font-size: clamp(42px, 5vw, 64px);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1;
	margin: 0;
}

.hh-ref-journey__head > p {
	color: #5b6157;
	font-family: var(--hh-sans);
	font-size: 15.5px;
	line-height: 1.8;
	margin: 22px auto 0;
	max-width: 800px;
}

.hh-ref-journey__layout {
	align-items: stretch;
	display: grid;
	gap: 30px;
	grid-template-columns: 0.92fr 1.08fr;
	margin: 0 auto;
	max-width: 1180px;
	position: relative;
	z-index: 1;
}

.hh-ref-journey__story {
	background: #fffdf7;
	border: 1px solid var(--hh-line, #e5d8c4);
	border-radius: 32px;
	box-shadow: 0 22px 60px rgba(31, 53, 37, 0.08);
	padding: 26px;
}

.hh-ref-journey__visual {
	border-radius: 24px;
	margin: 0;
	min-height: 300px;
	overflow: hidden;
	position: relative;
}

.hh-ref-journey__visual img {
	display: block;
	height: 100%;
	left: 0;
	object-fit: cover;
	position: absolute;
	top: 0;
	width: 100%;
}

.hh-ref-journey__badge {
	background: #fffdf6;
	border-radius: 999px;
	color: var(--hh-forest);
	font-family: var(--hh-sans);
	font-size: 11px;
	font-weight: 800;
	left: 22px;
	letter-spacing: 0.14em;
	padding: 11px 17px;
	position: absolute;
	text-transform: uppercase;
	top: 22px;
	z-index: 2;
}

.hh-ref-journey__story h3 {
	color: #20351d;
	font-family: var(--hh-serif);
	font-size: clamp(32px, 3vw, 40px);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.05;
	margin: 28px 6px 14px;
}

.hh-ref-journey__story > p {
	color: #687267;
	font-family: var(--hh-sans);
	font-size: 15px;
	line-height: 1.75;
	margin: 0 6px;
}

.hh-ref-journey__steps {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(3, 1fr);
	margin: 28px 6px 4px;
}

.hh-ref-journey__steps span {
	background: #f7efe3;
	border: 1px solid var(--hh-line, #e5d8c4);
	border-radius: 999px;
	color: #20351d;
	font-family: var(--hh-sans);
	font-size: 13px;
	font-weight: 700;
	padding: 13px 10px;
	text-align: center;
}

.hh-ref-journey__panel {
	background:
		radial-gradient(circle at 88% 8%, rgba(201, 154, 69, 0.18), transparent 26%),
		linear-gradient(145deg, var(--hh-forest), #14331f);
	border-radius: 32px;
	box-shadow: 0 30px 80px rgba(21, 62, 40, 0.26);
	color: #fffdf6;
	overflow: hidden;
	padding: 40px 42px;
	position: relative;
}

.hh-ref-journey__panel::before {
	color: rgba(255, 253, 246, 0.06);
	content: "5";
	font-family: var(--hh-serif);
	font-size: 180px;
	font-weight: 700;
	line-height: 1;
	position: absolute;
	right: 44px;
	top: -16px;
}

.hh-ref-journey__panel h3 {
	color: #fffdf6;
	font-family: var(--hh-serif);
	font-size: 36px;
	font-weight: 600;
	line-height: 1.04;
	margin: 0;
	position: relative;
}

.hh-ref-journey__subline {
	color: rgba(255, 253, 246, 0.74);
	font-family: var(--hh-sans);
	font-size: 14px;
	margin: 12px 0 30px;
	position: relative;
}

.hh-ref-journey__timeline {
	display: grid;
	gap: 13px;
	list-style: none;
	margin: 0;
	padding: 0 0 0 63px;
	position: relative;
}

.hh-ref-journey__timeline::before {
	background: rgba(255, 253, 246, 0.22);
	bottom: 22px;
	content: "";
	left: 22px;
	position: absolute;
	top: 22px;
	width: 2px;
}

.hh-ref-journey__timeline li {
	background: rgba(255, 253, 246, 0.07);
	border: 1px solid rgba(255, 253, 246, 0.10);
	border-radius: 18px;
	min-height: 74px;
	padding: 16px 18px;
	position: relative;
}

.hh-ref-journey__timeline li::before {
	background: var(--hh-gold);
	border-radius: 50%;
	color: #14331f;
	content: attr(data-step);
	display: grid;
	font-family: var(--hh-sans);
	font-size: 12px;
	font-weight: 900;
	height: 38px;
	left: -62px;
	place-items: center;
	position: absolute;
	top: 17px;
	width: 38px;
}

.hh-ref-journey__timeline strong {
	color: #fffdf6;
	display: block;
	font-family: var(--hh-sans);
	font-size: 15.5px;
	margin-bottom: 5px;
}

.hh-ref-journey__timeline li p {
	color: rgba(255, 253, 246, 0.78);
	font-family: var(--hh-sans);
	font-size: 13px;
	line-height: 1.55;
	margin: 0;
}

.hh-ref-journey__ribbon {
	background: rgba(255, 253, 247, 0.72);
	border: 1px solid rgba(201, 154, 69, 0.24);
	border-radius: 999px;
	color: #20351d;
	font-family: var(--hh-sans);
	font-size: 14.5px;
	line-height: 1.6;
	margin: 28px auto 0;
	max-width: 1020px;
	padding: 18px 26px;
	position: relative;
	text-align: center;
	z-index: 1;
}

@media (max-width: 980px) {
	.hh-ref-journey__layout {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.hh-ref-journey {
		padding: 64px 18px 72px;
	}

	.hh-ref-journey__story,
	.hh-ref-journey__panel {
		border-radius: 24px;
	}

	.hh-ref-journey__story {
		padding: 18px;
	}

	.hh-ref-journey__panel {
		padding: 30px 24px;
	}

	.hh-ref-journey__steps {
		grid-template-columns: 1fr;
	}

	.hh-ref-journey__ribbon {
		border-radius: 24px;
	}
}

/* Make the entire package card clickable (stretched link over existing Book button) */
.hh-pkg-card {
	position: relative;
}
.hh-pkg-card__book {
	position: static;
}
.hh-pkg-card__book::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
}

/* === Brand button colour overrides — blue→green to match template (2026-06-20) === */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce input.button.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce #respond input#submit,
.woocommerce #respond input#submit.alt,
.woocommerce-page a.button,
.woocommerce-page button.button,
.woocommerce-page input.button,
.wc-proceed-to-checkout a.checkout-button,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
button.single_add_to_cart_button,
.wc-block-components-button:not(.is-link),
.wp-block-woocommerce-cart .wc-block-cart__submit-button,
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button,
.wp-block-search .wp-block-search__button,
.search-submit,
button.search-submit,
#searchform #searchsubmit,
.search-form .search-submit {
	background-color: var(--hh-forest, #1f4e2e) !important;
	border-color: var(--hh-forest, #1f4e2e) !important;
	color: #ffffff !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce input.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce #respond input#submit:hover,
.wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
button.single_add_to_cart_button:hover,
.wc-block-components-button:not(.is-link):hover,
.wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover,
.wp-block-search .wp-block-search__button:hover,
.search-submit:hover,
#searchform #searchsubmit:hover {
	background-color: var(--hh-moss, #496f35) !important;
	border-color: var(--hh-moss, #496f35) !important;
	color: #ffffff !important;
}
