:root {
	--sp-ink: #111315;
	--sp-muted: #646b72;
	--sp-subtle: #8b9298;
	--sp-soft: #f3f5f5;
	--sp-panel: #ffffff;
	--sp-line: #e0e4e5;
	--sp-green: #0f766e;
	--sp-green-dark: #0a4f4b;
	--sp-sun: #f3b238;
	--sp-coral: #e85d3f;
	--sp-blue: #3e6ff4;
	--sp-radius: 8px;
	--sp-shadow: 0 18px 42px rgba(17, 19, 21, 0.12);
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	background: #f8f9f7;
	color: var(--sp-ink);
	font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	font-size: 16px;
	line-height: 1.55;
}

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

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

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	height: 1px;
	overflow: hidden;
	position: absolute;
	width: 1px;
}

.screen-reader-text:focus {
	background: var(--sp-panel);
	clip: auto;
	height: auto;
	left: 1rem;
	padding: 0.75rem 1rem;
	top: 1rem;
	width: auto;
	z-index: 30;
}

.site-shell {
	margin: 0 auto;
	max-width: 1240px;
	padding: 0 22px;
	width: 100%;
}

.site-header {
	background: rgba(255, 255, 255, 0.96);
	border-bottom: 1px solid var(--sp-line);
	position: sticky;
	top: 0;
	z-index: 20;
}

.announcement-bar {
	background: var(--sp-ink);
	color: #fff;
	font-size: 0.88rem;
	font-weight: 750;
	text-align: center;
}

.announcement-bar a {
	align-items: center;
	display: flex;
	gap: 10px;
	justify-content: center;
	min-height: 38px;
	padding: 7px 16px;
}

.announcement-bar strong {
	color: var(--sp-sun);
}

.trust-strip {
	background: #f0f3f1;
	border-bottom: 1px solid var(--sp-line);
	color: #37403e;
	font-size: 0.78rem;
	font-weight: 800;
	text-transform: uppercase;
}

.trust-strip__inner {
	align-items: center;
	display: flex;
	gap: 18px;
	justify-content: center;
	min-height: 32px;
}

.trust-strip span {
	align-items: center;
	display: inline-flex;
	gap: 7px;
	white-space: nowrap;
}

.trust-strip span::before {
	background: var(--sp-green);
	border-radius: 50%;
	content: "";
	height: 7px;
	width: 7px;
}

.site-header__main {
	align-items: center;
	display: grid;
	gap: 18px;
	grid-template-columns: auto minmax(280px, 1fr) auto;
	min-height: 78px;
}

.brand {
	align-items: center;
	display: inline-flex;
	font-weight: 900;
	gap: 10px;
	letter-spacing: 0;
	white-space: nowrap;
}

.brand__mark {
	align-items: center;
	background: linear-gradient(135deg, var(--sp-sun), #ffe1a0);
	border: 2px solid var(--sp-ink);
	border-radius: 50%;
	color: var(--sp-ink);
	display: inline-flex;
	font-size: 0.8rem;
	height: 42px;
	justify-content: center;
	width: 42px;
}

.brand__text {
	font-size: 1.38rem;
}

.header-search .search-form {
	max-width: none;
}

.header-search .search-form .button {
	min-width: 96px;
}

.header-actions {
	align-items: center;
	display: flex;
	gap: 10px;
	justify-content: flex-end;
}

.header-actions a {
	border: 1px solid var(--sp-line);
	border-radius: 999px;
	font-size: 0.88rem;
	font-weight: 850;
	padding: 9px 13px;
}

.cart-link {
	align-items: center;
	background: var(--sp-ink);
	color: #fff;
	display: inline-flex;
	gap: 8px;
}

.cart-link span {
	align-items: center;
	background: var(--sp-sun);
	border-radius: 50%;
	color: var(--sp-ink);
	display: inline-flex;
	font-size: 0.75rem;
	height: 22px;
	justify-content: center;
	min-width: 22px;
}

.site-header__nav {
	border-top: 1px solid var(--sp-line);
}

.primary-nav__menu,
.footer-nav {
	align-items: center;
	display: flex;
	gap: 4px;
	justify-content: center;
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-nav a {
	border-radius: 999px;
	color: #303638;
	display: inline-flex;
	font-size: 0.9rem;
	font-weight: 850;
	padding: 12px 16px;
}

.primary-nav a:hover,
.primary-nav .current-menu-item > a {
	background: #eef5f3;
	color: var(--sp-green-dark);
}

.nav-toggle {
	background: transparent;
	border: 0;
	display: none;
	height: 42px;
	padding: 8px;
	width: 42px;
}

.nav-toggle span:not(.screen-reader-text) {
	background: var(--sp-ink);
	display: block;
	height: 2px;
	margin: 5px 0;
	width: 24px;
}

.home-hero {
	background:
		radial-gradient(circle at 82% 24%, rgba(243, 178, 56, 0.46), transparent 26%),
		linear-gradient(135deg, #f5fbf8 0%, #eef6f3 52%, #fff1d8 100%);
	border-bottom: 1px solid var(--sp-line);
	overflow: hidden;
	padding: 16px 0 44px;
}

.category-rail {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	margin-bottom: 20px;
}

.shop-category-rail {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	padding-bottom: 0;
	padding-top: 22px;
}

.category-chip {
	align-items: center;
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	box-shadow: 0 8px 22px rgba(17, 19, 21, 0.05);
	display: flex;
	gap: 11px;
	min-height: 72px;
	padding: 10px;
}

.category-chip:hover {
	border-color: var(--line-accent);
	transform: translateY(-1px);
}

.category-chip__icon {
	align-items: center;
	background: color-mix(in srgb, var(--line-accent) 16%, white);
	border: 1px solid color-mix(in srgb, var(--line-accent) 48%, white);
	border-radius: 50%;
	color: var(--line-accent);
	display: inline-flex;
	flex: 0 0 42px;
	font-weight: 950;
	height: 42px;
	justify-content: center;
	width: 42px;
}

.category-chip strong,
.category-chip small {
	display: block;
	line-height: 1.18;
}

.category-chip strong {
	font-size: 0.94rem;
}

.category-chip small {
	color: var(--sp-muted);
	font-size: 0.76rem;
	margin-top: 2px;
}

.home-hero__grid {
	align-items: center;
	display: grid;
	gap: 44px;
	grid-template-columns: minmax(0, 0.94fr) minmax(380px, 1.06fr);
	min-height: 520px;
}

.home-hero h1 {
	font-size: clamp(3.7rem, 9vw, 8rem);
	line-height: 0.88;
	margin: 0 0 20px;
}

.home-hero p {
	color: #35413f;
	font-size: clamp(1.1rem, 2vw, 1.36rem);
	font-weight: 650;
	max-width: 660px;
}

.eyebrow {
	color: var(--sp-green);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0;
	margin: 0 0 10px;
	text-transform: uppercase;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 28px;
}

.button,
.wp-element-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	align-items: center;
	border: 1px solid var(--sp-ink);
	border-radius: var(--sp-radius);
	cursor: pointer;
	display: inline-flex;
	font-weight: 900;
	justify-content: center;
	min-height: 46px;
	padding: 0.76rem 1.05rem;
	text-decoration: none;
}

.button--primary,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	background: var(--sp-ink);
	color: var(--sp-panel);
}

.button--ghost {
	background: var(--sp-panel);
	color: var(--sp-ink);
}

.hero-product-stage {
	min-height: 430px;
	position: relative;
}

.hero-pack {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.72), transparent 30%),
		linear-gradient(145deg, #17211f, #344642);
	border: 1px solid rgba(255, 255, 255, 0.5);
	border-radius: 18px;
	box-shadow: var(--sp-shadow);
	color: #fff;
	display: grid;
	height: 340px;
	padding: 26px;
	position: absolute;
	width: 230px;
}

.hero-pack::after {
	background: linear-gradient(135deg, var(--sp-sun), #ffe5a4);
	border-radius: 999px;
	bottom: 26px;
	content: "";
	height: 10px;
	left: 26px;
	position: absolute;
	right: 26px;
}

.hero-pack span {
	align-items: center;
	background: #fff;
	border-radius: 50%;
	color: var(--sp-ink);
	display: inline-flex;
	font-weight: 950;
	height: 48px;
	justify-content: center;
	width: 48px;
}

.hero-pack strong {
	align-self: center;
	font-size: 2rem;
	line-height: 0.98;
}

.hero-pack small {
	align-self: end;
	color: rgba(255, 255, 255, 0.75);
	font-size: 1rem;
	font-weight: 850;
	padding-bottom: 22px;
}

.hero-pack--front {
	right: 18%;
	top: 42px;
	transform: rotate(4deg);
	z-index: 2;
}

.hero-pack--back {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.72), transparent 30%),
		linear-gradient(145deg, #f5f7fb, #d8e4ff);
	color: var(--sp-ink);
	left: 12%;
	top: 94px;
	transform: rotate(-8deg);
}

.hero-pack--back small {
	color: #425069;
}

.hero-proof {
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	bottom: 34px;
	box-shadow: var(--sp-shadow);
	display: grid;
	gap: 2px;
	padding: 16px 18px;
	position: absolute;
	right: 6%;
	width: 230px;
	z-index: 3;
}

.hero-proof strong {
	font-size: 1.4rem;
}

.hero-proof span {
	color: var(--sp-muted);
	font-size: 0.9rem;
}

.benefit-band {
	background: var(--sp-panel);
	border-bottom: 1px solid var(--sp-line);
}

.benefit-band__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.benefit-band__grid > div {
	border-left: 1px solid var(--sp-line);
	display: grid;
	gap: 2px;
	padding: 18px 22px;
}

.benefit-band__grid > div:last-child {
	border-right: 1px solid var(--sp-line);
}

.benefit-band strong {
	font-size: 0.98rem;
}

.benefit-band span {
	color: var(--sp-muted);
	font-size: 0.88rem;
}

.site-section,
.shop-shelf {
	padding: 66px 0;
}

.site-section--muted {
	background: #eef3ef;
	border-bottom: 1px solid var(--sp-line);
	border-top: 1px solid var(--sp-line);
}

.section-heading,
.shelf-heading {
	align-items: end;
	display: flex;
	gap: 20px;
	justify-content: space-between;
	margin-bottom: 26px;
}

.section-heading h2,
.shelf-heading h2,
.trust-grid h2 {
	font-size: clamp(2rem, 4vw, 3.35rem);
	line-height: 1.04;
	margin: 0;
	max-width: 820px;
}

.shelf-heading .text-link {
	white-space: nowrap;
}

.line-grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(5, minmax(0, 1fr));
}

.line-card {
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	display: grid;
	gap: 11px;
	min-height: 248px;
	overflow: hidden;
	padding: 19px;
	position: relative;
}

.line-card::before {
	background: var(--line-accent);
	content: "";
	height: 6px;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.line-card:hover {
	border-color: var(--line-accent);
	box-shadow: var(--sp-shadow);
	transform: translateY(-2px);
}

.line-card__kicker {
	color: var(--line-accent);
	font-size: 0.78rem;
	font-weight: 950;
	text-transform: uppercase;
}

.line-card strong {
	font-size: 1.25rem;
	line-height: 1.08;
}

.line-card em {
	color: #3e474a;
	font-size: 0.92rem;
	font-style: normal;
}

.line-card span:last-child {
	align-self: end;
	color: var(--sp-muted);
	font-size: 0.84rem;
}

.trust-grid {
	display: grid;
	gap: 36px;
	grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
}

.trust-list {
	display: grid;
	gap: 10px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.trust-list li,
.product-trust-panel span {
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	font-weight: 800;
	padding: 14px 16px;
}

.page-hero {
	background: linear-gradient(135deg, #f5fbf8 0%, #fff2d8 100%);
	border-bottom: 1px solid var(--sp-line);
	padding: 54px 0;
}

.page-hero h1 {
	font-size: clamp(2.3rem, 5vw, 4.8rem);
	line-height: 0.98;
	margin: 0 0 18px;
	max-width: 940px;
}

.archive-description,
.page-hero p {
	color: var(--sp-muted);
	max-width: 760px;
}

.content-grid,
.entry-content-wrap,
.woo-shell {
	padding-bottom: 70px;
	padding-top: 44px;
}

.entry-content {
	font-size: 1.06rem;
	max-width: 840px;
}

.entry-content a {
	color: var(--sp-green);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.entry-content h2,
.entry-content h3 {
	line-height: 1.12;
	margin-top: 2em;
}

.line-hero {
	border-top: 6px solid var(--line-accent, var(--sp-green));
}

.line-layout {
	display: grid;
	gap: 42px;
	grid-template-columns: minmax(0, 1fr) 340px;
}

.line-sidebar {
	align-self: start;
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	padding: 22px;
}

.line-sidebar h2 {
	font-size: 1.1rem;
	margin: 0 0 18px;
}

.line-sidebar dl {
	margin: 0 0 22px;
}

.line-sidebar dt {
	color: var(--sp-green);
	font-size: 0.78rem;
	font-weight: 900;
	text-transform: uppercase;
}

.line-sidebar dd {
	margin: 0 0 16px;
}

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

.post-card {
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	overflow: hidden;
}

.post-card__media {
	aspect-ratio: 16 / 10;
	background: var(--sp-soft);
	display: block;
	overflow: hidden;
}

.post-card__media img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.post-card__body {
	padding: 20px;
}

.post-card h2 {
	font-size: 1.32rem;
	line-height: 1.18;
	margin: 0 0 12px;
}

.post-card p {
	color: var(--sp-muted);
}

.text-link {
	color: var(--sp-green-dark);
	font-weight: 900;
}

.post-meta {
	color: var(--sp-muted);
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.research-disclaimer {
	background: #fff8e8;
	border: 1px solid #f0d59b;
	border-radius: var(--sp-radius);
	color: #563f12;
	display: grid;
	gap: 4px;
	margin-top: 24px;
	padding: 14px 16px;
}

.product-trust-panel {
	display: grid;
	gap: 8px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin: 20px 0;
}

.woocommerce ul.products,
.sunpept-product-row,
.research-product-row {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce ul.products li.product,
.research-product-card {
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	display: flex;
	flex-direction: column;
	min-height: 100%;
	overflow: hidden;
	padding: 12px;
	position: relative;
}

.woocommerce ul.products li.product:hover,
.research-product-card:hover {
	box-shadow: var(--sp-shadow);
	transform: translateY(-2px);
}

.research-product-card:hover {
	border-color: var(--line-accent);
}

.research-product-card__badge {
	background: var(--line-accent);
	border-radius: 999px;
	color: #fff;
	font-size: 0.74rem;
	font-weight: 950;
	left: 20px;
	padding: 5px 9px;
	position: absolute;
	top: 20px;
	z-index: 2;
}

.research-product-card__visual {
	align-items: center;
	aspect-ratio: 1 / 1;
	background:
		radial-gradient(circle at 70% 24%, rgba(255, 255, 255, 0.76), transparent 22%),
		linear-gradient(135deg, color-mix(in srgb, var(--line-accent) 26%, white), #f2f5f4);
	border-radius: 6px;
	display: flex;
	justify-content: center;
	width: 100%;
}

.research-product-card__visual span {
	align-items: center;
	background: var(--sp-ink);
	border-radius: 50%;
	color: var(--sp-sun);
	display: inline-flex;
	font-weight: 950;
	height: 78px;
	justify-content: center;
	width: 78px;
}

.research-product-card strong {
	font-size: 1.08rem;
	line-height: 1.18;
	margin: 12px 0 2px;
}

.research-product-card small {
	color: var(--sp-muted);
	font-weight: 750;
}

.woocommerce ul.products li.product a img {
	aspect-ratio: 1 / 1;
	background:
		linear-gradient(135deg, rgba(15, 118, 110, 0.12), rgba(243, 178, 56, 0.16)),
		#f1f4f4;
	border-radius: 6px;
	object-fit: cover;
	width: 100%;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 1.02rem;
	line-height: 1.18;
	margin: 12px 0 6px;
	min-height: 2.36em;
}

.loop-research-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 10px;
}

.loop-research-badges span {
	background: #eef5f3;
	border: 1px solid #d6e5e1;
	border-radius: 999px;
	color: var(--sp-green-dark);
	font-size: 0.68rem;
	font-weight: 950;
	padding: 4px 7px;
	text-transform: uppercase;
}

.woocommerce ul.products li.product .price {
	color: var(--sp-green-dark);
	display: block;
	font-size: 1.08rem;
	font-weight: 950;
	margin: 6px 0 12px;
}

.woocommerce ul.products li.product .button {
	margin-top: auto;
	width: 100%;
}

.woocommerce span.onsale {
	background: var(--sp-coral);
	border-radius: 999px;
	color: #fff;
	font-size: 0.76rem;
	font-weight: 950;
	left: 20px;
	min-height: auto;
	padding: 6px 10px;
	position: absolute;
	top: 20px;
	z-index: 2;
}

.woocommerce div.product {
	display: grid;
	gap: 36px;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr);
}

.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related {
	grid-column: 1 / -1;
}

.woocommerce div.product .summary {
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	padding: 24px;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--sp-green-dark);
	font-size: 1.46rem;
	font-weight: 950;
}

.quantity .qty {
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	min-height: 44px;
	padding: 0 10px;
	width: 76px;
}

.site-footer {
	background: var(--sp-ink);
	color: rgba(255, 255, 255, 0.84);
	padding: 54px 0 24px;
}

.site-footer__grid {
	display: grid;
	gap: 36px;
	grid-template-columns: 1.2fr 0.8fr 1fr;
}

.brand--footer .brand__mark {
	background: var(--sp-sun);
	color: var(--sp-ink);
}

.site-footer h2 {
	color: #fff;
	font-size: 1rem;
	margin: 0 0 12px;
}

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

.site-footer li + li {
	margin-top: 8px;
}

.site-footer .research-disclaimer {
	background: rgba(255, 248, 232, 0.08);
	border-color: rgba(240, 213, 155, 0.28);
	color: rgba(255, 255, 255, 0.82);
}

.site-footer__bottom {
	align-items: center;
	border-top: 1px solid rgba(255, 255, 255, 0.14);
	display: flex;
	justify-content: space-between;
	margin-top: 38px;
	padding-top: 22px;
}

.empty-state {
	background: var(--sp-panel);
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	padding: 28px;
}

.search-form {
	align-items: stretch;
	display: flex;
	gap: 8px;
	max-width: 620px;
}

.search-form label {
	flex: 1;
}

input[type="search"],
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
textarea,
select {
	background: #fff;
	border: 1px solid var(--sp-line);
	border-radius: var(--sp-radius);
	font: inherit;
	min-height: 44px;
	padding: 0.7rem 0.8rem;
	width: 100%;
}

@media (max-width: 1100px) {
	.category-rail,
	.shop-category-rail,
	.line-grid,
	.woocommerce ul.products,
	.sunpept-product-row,
	.research-product-row {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.site-header__main {
		grid-template-columns: auto 1fr auto;
	}

	.header-search {
		grid-column: 1 / -1;
		order: 3;
	}
}

@media (max-width: 900px) {
	.home-hero__grid,
	.trust-grid,
	.woocommerce div.product,
	.line-layout,
	.site-footer__grid,
	.benefit-band__grid {
		grid-template-columns: 1fr;
	}

	.home-hero__grid {
		min-height: 0;
	}

	.hero-product-stage {
		min-height: 360px;
	}

	.hero-pack--front {
		right: 12%;
	}

	.hero-pack--back {
		left: 8%;
	}
}

@media (max-width: 760px) {
	.site-shell {
		padding: 0 16px;
	}

	.announcement-bar a {
		align-items: center;
		flex-direction: column;
		gap: 0;
		line-height: 1.25;
		padding: 8px 12px;
	}

	.trust-strip__inner {
		justify-content: flex-start;
		overflow-x: auto;
	}

	.nav-toggle {
		display: inline-block;
	}

	.site-header__main {
		gap: 12px;
		grid-template-columns: auto 1fr auto;
		min-height: 66px;
	}

	.brand__mark {
		height: 36px;
		width: 36px;
	}

	.brand__text {
		font-size: 1.12rem;
	}

	.header-actions a:not(.cart-link) {
		display: none;
	}

	.header-actions a {
		font-size: 0.8rem;
		padding: 8px 10px;
	}

	.site-header__nav {
		border-top: 0;
		padding: 0;
	}

	.primary-nav {
		background: #fff;
		border-bottom: 1px solid var(--sp-line);
		display: none;
		left: 0;
		padding: 14px 16px;
		position: absolute;
		right: 0;
		top: 100%;
	}

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

	.primary-nav__menu,
	.footer-nav,
	.site-footer__bottom {
		align-items: stretch;
		flex-direction: column;
	}

	.primary-nav a {
		justify-content: center;
	}

	.category-rail,
	.shop-category-rail {
		display: flex;
		overflow-x: auto;
		padding-bottom: 8px;
	}

	.category-chip {
		flex: 0 0 210px;
	}

	.home-hero {
		padding: 14px 0 34px;
	}

	.home-hero h1 {
		font-size: clamp(3.2rem, 18vw, 5rem);
	}

	.hero-product-stage {
		min-height: 300px;
	}

	.hero-pack {
		height: 255px;
		width: 176px;
	}

	.hero-pack strong {
		font-size: 1.45rem;
	}

	.hero-proof {
		bottom: 6px;
		right: 0;
		width: 210px;
	}

	.section-heading,
	.shelf-heading {
		align-items: flex-start;
		flex-direction: column;
	}

	.line-grid,
	.post-list,
	.woocommerce ul.products,
	.sunpept-product-row,
	.research-product-row,
	.product-trust-panel {
		grid-template-columns: 1fr;
	}

	.site-section,
	.shop-shelf {
		padding: 48px 0;
	}

	.search-form {
		flex-direction: column;
	}
}
