/*
Theme Name: Themify Ultra Child
Theme URI: https://themify.me/themes/ultra
Description: Minimal child theme scaffold for the Coloring Library Free project.
Author: Codex
Template: themify-ultra
Version: 1.0.0
Text Domain: themify-ultra-child
*/

:root {
	--clf-accent: #1d5f43;
	--clf-accent-strong: #124632;
	--clf-highlight: #f0c56d;
	--clf-highlight-soft: #fff1cf;
	--clf-blush: #f2ddd1;
	--clf-surface: #faf4eb;
	--clf-surface-strong: #f3e6d5;
	--clf-card: rgba(255, 252, 245, 0.88);
	--clf-card-solid: #fffdf8;
	--clf-ink: #1f2f27;
	--clf-ink-soft: #4f5c56;
	--clf-border: rgba(42, 53, 45, 0.12);
	--clf-shadow: 0 26px 60px rgba(32, 34, 28, 0.12);
	--clf-shadow-strong: 0 34px 90px rgba(29, 38, 34, 0.16);
	--clf-radius-xl: 32px;
	--clf-radius-lg: 24px;
	--clf-radius-md: 18px;
	--clf-max: 1060px;
	--clf-page-gutter: clamp(1.2rem, 3vw, 2.8rem);
	--clf-section-gap: clamp(1.9rem, 4vw, 3.2rem);
}

body {
	background:
		radial-gradient(circle at top left, rgba(240, 197, 109, 0.34), transparent 24%),
		radial-gradient(circle at 88% 16%, rgba(182, 214, 189, 0.48), transparent 22%),
		linear-gradient(180deg, #fffdf8 0%, #f7f0e4 54%, #f5ecdf 100%);
	color: var(--clf-ink);
	font-family: "Plus Jakarta Sans", "Public Sans", "Segoe UI", sans-serif;
}

body,
button,
input,
select,
textarea {
	font-family: "Plus Jakarta Sans", "Public Sans", "Segoe UI", sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
.post-title,
.page-title {
	color: var(--clf-ink);
	font-family: "Fraunces", Georgia, serif;
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.04;
}

a {
	color: var(--clf-accent-strong);
}

a:hover,
a:focus {
	color: var(--clf-accent);
}

#pagewrap {
	background: transparent;
}

.pagewidth {
	box-sizing: border-box;
	max-width: calc(var(--clf-max) + (var(--clf-page-gutter) * 2));
	padding-inline: var(--clf-page-gutter);
	width: 100%;
}

#headerwrap {
	background: rgba(255, 251, 245, 0.8);
	backdrop-filter: blur(14px);
	border-bottom: 1px solid rgba(35, 48, 41, 0.08);
	min-height: 76px;
	position: sticky;
	top: 0;
	z-index: 999;
}

#header {
	display: flex;
	align-items: center;
	box-sizing: border-box;
	justify-content: space-between;
	gap: 1.25rem;
	min-height: 72px;
	padding: 1.15rem 0;
}

#site-logo {
	line-height: 1;
	margin: 0;
}

#site-logo a {
	align-items: center;
	display: inline-flex;
	line-height: 1;
}

#site-logo a span {
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.4rem, 1.1rem + 1vw, 2rem);
	font-weight: 700;
	letter-spacing: -0.04em;
	line-height: 1;
}

#site-description {
	color: var(--clf-ink-soft);
	font-size: 0.95rem;
}

#main-nav-wrap {
	margin-left: auto;
}

#main-nav {
	display: flex;
	gap: 0.35rem;
	align-items: center;
}

#main-nav a {
	border-radius: 999px;
	color: var(--clf-ink);
	font-size: 0.95rem;
	font-weight: 700;
	padding: 0.8rem 1rem;
	text-decoration: none;
	transition: background-color 160ms ease, color 160ms ease, transform 160ms ease;
}

#main-nav a:hover,
#main-nav a:focus {
	background: rgba(29, 95, 67, 0.08);
	color: var(--clf-accent-strong);
	transform: translateY(-1px);
}

.clf-language-switcher-wrap {
	display: flex;
	justify-content: flex-end;
	margin-top: 0.45rem;
}

.clf-language-switcher-header {
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid rgba(35, 48, 41, 0.08);
	border-radius: 999px;
	box-shadow: 0 8px 24px rgba(25, 33, 28, 0.08);
	padding: 0.2rem;
}

.clf-language-switcher-header .clf-language-switcher__list {
	gap: 0.2rem;
}

.clf-language-switcher-header .clf-language-switcher__link {
	border-color: transparent;
	min-height: 30px;
	min-width: 30px;
	padding: 0.25rem;
}

.clf-language-switcher-header .clf-language-switcher__flag {
	height: 10px;
	width: 15px;
}

.header-horizontal #header {
	align-items: center;
	padding-bottom: 1.15rem;
	padding-right: 4.5rem;
	padding-top: 1.15rem;
	position: relative;
}

.header-horizontal #headerwrap.fixed-header,
.header-horizontal .fixed-header {
	min-height: 70px;
}

.header-horizontal #headerwrap.fixed-header #header,
.header-horizontal .fixed-header #header {
	align-items: center;
	min-height: 66px;
	padding-bottom: 0.86rem;
	padding-top: 0.86rem;
}

.header-horizontal #headerwrap.fixed-header #site-logo a span,
.header-horizontal .fixed-header #site-logo a span {
	font-size: clamp(1.45rem, 1.08rem + 0.8vw, 1.9rem);
	line-height: 1;
}

.header-horizontal #mobile-menu.sidemenu {
	background: transparent;
	box-shadow: none;
	color: inherit;
	display: block;
	flex: 1 1 auto;
	height: auto;
	margin-left: auto;
	min-width: 0;
	overflow: visible;
	padding: 0;
	position: static;
	right: auto;
	width: auto;
	z-index: auto;
}

.header-horizontal .navbar-wrapper,
.header-horizontal #main-nav-wrap {
	min-width: 0;
	width: 100%;
}

.header-horizontal #main-nav {
	float: none;
	flex-wrap: wrap;
	justify-content: flex-end;
	min-height: 44px;
	row-gap: 0.2rem;
}

.header-horizontal #main-nav li {
	float: none;
	position: relative;
}

.header-horizontal #headerwrap #main-nav a {
	font-size: 0.9rem;
	padding: 0.78rem 0.88rem;
	white-space: nowrap;
}

.header-horizontal #headerwrap.fixed-header #main-nav a,
.header-horizontal .fixed-header #main-nav a {
	font-size: 0.9rem;
	padding-bottom: 0.72rem;
	padding-top: 0.72rem;
}

#main-nav .clf-nav-dropdown-parent > a,
#main-nav .clf-category-dropdown-parent > a {
	align-items: center;
	display: inline-flex;
	gap: 0.38rem;
}

#main-nav .clf-nav-dropdown-parent .child-arrow,
#main-nav .clf-category-dropdown-parent .child-arrow {
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 5px solid currentColor;
	content: "";
	display: inline-block;
	height: 0;
	margin-left: 0.02rem;
	margin-top: 0.12rem;
	opacity: 0.68;
	position: static;
	width: 0;
}

.header-horizontal #main-nav > .clf-nav-dropdown-parent::after,
.header-horizontal #main-nav > .clf-category-dropdown-parent::after {
	content: "";
	display: block;
	height: 0.75rem;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 100%;
	z-index: 1001;
}

.header-horizontal #main-nav > .clf-nav-dropdown-parent:hover::after,
.header-horizontal #main-nav > .clf-nav-dropdown-parent:focus-within::after,
.header-horizontal #main-nav > .clf-category-dropdown-parent:hover::after,
.header-horizontal #main-nav > .clf-category-dropdown-parent:focus-within::after {
	pointer-events: auto;
}

.header-horizontal #main-nav .clf-nav-dropdown-parent > .sub-menu,
#main-nav .clf-nav-dropdown-parent > .sub-menu,
.header-horizontal #main-nav .clf-category-dropdown-parent > .sub-menu,
#main-nav .clf-category-dropdown-parent > .sub-menu {
	background: rgba(255, 252, 245, 0.96);
	border: 1px solid rgba(35, 48, 41, 0.1);
	border-radius: 22px;
	box-shadow: 0 24px 60px rgba(25, 33, 28, 0.16);
	display: block;
	left: 0;
	list-style: none;
	margin: 0;
	max-height: min(70vh, 520px);
	min-width: 230px;
	opacity: 0;
	overflow: auto;
	padding: 0.45rem;
	pointer-events: none;
	position: absolute;
	top: calc(100% + 0.45rem);
	transform: translateY(-6px);
	transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
	visibility: hidden;
	z-index: 1002;
}

#main-nav .clf-nav-dropdown-parent:hover > .sub-menu,
#main-nav .clf-nav-dropdown-parent:focus-within > .sub-menu,
#main-nav .clf-category-dropdown-parent:hover > .sub-menu,
#main-nav .clf-category-dropdown-parent:focus-within > .sub-menu {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
	visibility: visible;
}

.header-horizontal #headerwrap #main-nav .clf-nav-dropdown-parent > .sub-menu > li > a,
.header-horizontal #headerwrap #main-nav .clf-category-dropdown-item > a,
#main-nav .clf-nav-dropdown-parent > .sub-menu > li > a,
#main-nav .clf-category-dropdown-item > a {
	border-radius: 14px;
	display: block;
	font-size: 0.88rem;
	font-weight: 700;
	line-height: 1.2;
	padding: 0.72rem 0.82rem;
	white-space: nowrap;
}

.header-horizontal .clf-language-switcher-wrap {
	justify-content: flex-end;
	margin: 0;
	position: absolute;
	right: 0;
	top: 0.1rem;
	z-index: 4;
}

#footerwrap {
	background: rgba(32, 46, 38, 0.95);
	color: rgba(250, 247, 240, 0.84);
	margin-top: 4rem;
}

#footerwrap a,
#footerwrap .footer-text {
	color: rgba(250, 247, 240, 0.84);
}

#footer {
	padding-top: 2rem;
	padding-bottom: 2rem;
}

.clf-landing-shell,
.clf-archive-shell,
.clf-page {
	margin: 0 auto;
	max-width: var(--clf-max);
	padding: 2rem 1.2rem 4rem;
}

.clf-kicker {
	color: var(--clf-accent-strong);
	font-size: 0.88rem;
	font-weight: 800;
	letter-spacing: 0.18em;
	margin: 0 0 0.9rem;
	text-transform: uppercase;
}

.clf-landing-hero,
.clf-archive-hero,
.clf-supplies-band,
.clf-editorial-split,
.clf-search-band {
	background: linear-gradient(180deg, rgba(255, 253, 248, 0.96) 0%, rgba(255, 250, 243, 0.88) 100%);
	border: 1px solid var(--clf-border);
	border-radius: var(--clf-radius-xl);
	box-shadow: var(--clf-shadow);
}

.clf-landing-hero,
.clf-archive-hero {
	display: grid;
	grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
	gap: 2rem;
	padding: clamp(1.5rem, 2vw, 2rem);
	position: relative;
	overflow: hidden;
}

.clf-landing-hero::before,
.clf-archive-hero::before,
.clf-supplies-band::before {
	background: radial-gradient(circle at top left, rgba(240, 197, 109, 0.24), transparent 36%);
	content: "";
	inset: 0;
	position: absolute;
	pointer-events: none;
}

.clf-landing-copy,
.clf-archive-copy,
.clf-search-band-copy,
.clf-supplies-copy,
.clf-editorial-copy {
	position: relative;
	z-index: 1;
}

.clf-landing-title {
	font-size: clamp(2.9rem, 6vw, 5.1rem);
	margin: 0 0 1rem;
	max-width: 9.5ch;
}

.clf-landing-intro,
.clf-archive-description,
.clf-search-band-copy p,
.clf-editorial-copy p,
.clf-supplies-copy p {
	color: var(--clf-ink-soft);
	font-size: 1.05rem;
	line-height: 1.8;
	max-width: 60ch;
}

.clf-landing-benefits {
	display: grid;
	gap: 0.85rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin: 1.5rem 0 0;
	max-width: 52rem;
}

.clf-benefit-card {
	align-items: flex-start;
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid rgba(35, 48, 41, 0.08);
	border-radius: 24px;
	box-shadow: 0 16px 32px rgba(35, 48, 41, 0.08);
	display: flex;
	gap: 0.9rem;
	padding: 1rem 1.05rem;
}

.clf-benefit-icon {
	align-items: center;
	background: linear-gradient(135deg, rgba(29, 95, 67, 0.14), rgba(240, 197, 109, 0.22));
	border-radius: 18px;
	color: var(--clf-accent-strong);
	display: inline-flex;
	flex: 0 0 auto;
	height: 3rem;
	justify-content: center;
	width: 3rem;
}

.clf-benefit-icon svg {
	height: 1.45rem;
	width: 1.45rem;
}

.clf-benefit-copy {
	min-width: 0;
}

.clf-benefit-copy h2 {
	font-family: "Plus Jakarta Sans", sans-serif;
	font-size: 1rem;
	line-height: 1.25;
	margin: 0 0 0.3rem;
}

.clf-benefit-copy p {
	color: var(--clf-ink-soft);
	font-size: 0.92rem;
	line-height: 1.55;
	margin: 0;
}

.clf-landing-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	margin: 1.5rem 0 1.25rem;
}

.clf-landing-button {
	align-items: center;
	border-radius: 999px;
	display: inline-flex;
	font-size: 0.97rem;
	font-weight: 800;
	justify-content: center;
	min-height: 48px;
	padding: 0.9rem 1.2rem;
	text-decoration: none;
	transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}

.clf-landing-button:hover,
.clf-landing-button:focus {
	transform: translateY(-1px);
}

.clf-landing-button-primary {
	background: var(--clf-accent);
	box-shadow: 0 14px 30px rgba(29, 95, 67, 0.24);
	color: #fff;
}

.clf-landing-button-primary:hover,
.clf-landing-button-primary:focus {
	color: #fff;
}

.clf-landing-button-secondary {
	background: rgba(255, 255, 255, 0.74);
	border: 1px solid rgba(29, 95, 67, 0.18);
	color: var(--clf-accent-strong);
}

.clf-landing-pills,
.clf-shortcuts-band {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.clf-landing-pills li,
.clf-shortcut-chip {
	background: rgba(255, 255, 255, 0.7);
	border: 1px solid rgba(35, 48, 41, 0.08);
	border-radius: 999px;
	color: var(--clf-ink);
	font-size: 0.93rem;
	font-weight: 700;
	padding: 0.72rem 1rem;
	text-decoration: none;
}

.clf-shortcuts-band {
	margin: 1rem 0 2rem;
}

.clf-shortcut-chip:hover,
.clf-shortcut-chip:focus {
	background: rgba(29, 95, 67, 0.08);
	color: var(--clf-accent-strong);
}

.clf-landing-visual {
	display: grid;
	gap: 1rem;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	grid-template-rows: 1fr 1fr;
	position: relative;
}

.clf-hero-card {
	background: rgba(255, 255, 255, 0.8);
	border: 1px solid rgba(35, 48, 41, 0.08);
	border-radius: 28px;
	box-shadow: var(--clf-shadow-strong);
	margin: 0;
	overflow: hidden;
	transform: translateY(0);
	animation: clfFloat 7s ease-in-out infinite;
}

.clf-hero-card img,
.clf-archive-art img,
.clf-supplies-visual img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.clf-hero-card.is-tall {
	grid-row: 1 / span 2;
	min-height: 520px;
}

.clf-hero-card.is-small {
	min-height: 240px;
}

.clf-hero-card.is-offset {
	margin-left: 1.35rem;
}

.clf-search-band,
.clf-editorial-split,
.clf-supplies-band,
.clf-stats-shell,
.clf-section-shell {
	margin-top: 1.5rem;
}

.clf-search-band,
.clf-editorial-split {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	padding: 1.4rem;
}

.clf-search-band-form {
	align-self: center;
}

.clf-search-band .clf-search-form,
.clf-search-band .clf-filter-form {
	background: #fffefb;
	border-color: rgba(35, 48, 41, 0.08);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
	margin-bottom: 0;
}

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

.clf-editorial-panel {
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid rgba(35, 48, 41, 0.08);
	border-radius: var(--clf-radius-lg);
	padding: 1.2rem;
}

.clf-editorial-panel h3 {
	font-size: 1.45rem;
	margin-bottom: 0.5rem;
}

.clf-editorial-panel p {
	color: var(--clf-ink-soft);
	margin: 0;
}

.clf-section-shell,
.clf-stats-shell {
	background: rgba(255, 253, 247, 0.78);
	border: 1px solid var(--clf-border);
	border-radius: var(--clf-radius-xl);
	box-shadow: var(--clf-shadow);
	padding: 1.35rem;
}

.clf-section-shell-soft {
	background: linear-gradient(180deg, rgba(255, 246, 233, 0.88), rgba(250, 243, 232, 0.7));
}

.clf-section-header {
	align-items: end;
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1.15rem;
}

.clf-section-header h2,
.clf-archive-copy h1,
.clf-search-band h2,
.clf-editorial-copy h2,
.clf-supplies-copy h2 {
	font-size: clamp(2rem, 3vw, 3.25rem);
	margin: 0;
	max-width: 13ch;
}

.clf-archive-hero .clf-section-header h2 {
	max-width: none;
}

.clf-supplies-band {
	display: grid;
	gap: 1.35rem;
	grid-template-columns: minmax(0, 0.82fr) minmax(240px, 0.58fr) minmax(0, 0.88fr);
	padding: 1.35rem;
	position: relative;
}

.clf-supplies-visual {
	align-self: center;
	background: rgba(255, 255, 255, 0.7);
	border-radius: 24px;
	overflow: hidden;
}

.clf-supplies-products .clf-affiliate-block {
	margin-top: 0;
}

.clf-affiliate-block,
.clf-license-notice,
.clf-supporting-copy,
.clf-ad-slot,
.clf-metadata-panel,
.clf-download-cta,
.clf-public-stats > div,
.clf-stat-card,
.clf-category-card,
.clf-card,
.clf-affiliate-card {
	background: var(--clf-card);
	border: 1px solid rgba(35, 48, 41, 0.08);
	box-shadow: none;
}

.clf-grid,
.clf-affiliate-grid,
.clf-category-grid {
	gap: 1rem;
}

.clf-card,
.clf-affiliate-card,
.clf-category-card {
	border-radius: 22px;
}

.clf-card {
	display: flex;
	flex-direction: column;
	min-height: 100%;
}

.clf-card-image {
	aspect-ratio: 4 / 5.65;
	background: linear-gradient(180deg, #f7efe4, #ffffff);
	display: block;
	overflow: hidden;
}

.clf-card-image img {
	height: 100%;
	object-fit: contain;
	object-position: center center;
	transition: transform 220ms ease;
	width: 100%;
}

.clf-card:hover .clf-card-image img,
.clf-card:focus-within .clf-card-image img {
	transform: none;
}

.clf-card-body {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	padding: 1.1rem;
}

.clf-card-body h3 {
	font-size: 1.5rem;
	margin-bottom: 0.55rem;
}

.clf-card-body p:last-of-type {
	color: var(--clf-ink-soft);
	flex: 1 1 auto;
	line-height: 1.7;
}

.clf-card-tags {
	font-size: 0.95rem;
	font-weight: 700;
}

.clf-meta-list {
	font-size: 0.9rem;
	gap: 0.5rem;
}

.clf-meta-list li {
	background: rgba(29, 95, 67, 0.08);
	border-radius: 999px;
	padding: 0.4rem 0.7rem;
}

.clf-category-card {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(250, 243, 232, 0.92));
	display: flex;
	flex-direction: column;
	gap: 0.9rem;
	min-height: 100%;
	padding: 0.95rem;
	text-decoration: none;
	overflow: hidden;
}

.clf-category-card-media {
	aspect-ratio: 4 / 5;
	background: linear-gradient(180deg, #f6ebda, #fffdfa);
	border-radius: 18px;
	display: block;
	overflow: hidden;
	position: relative;
}

.clf-category-card-media img {
	display: block;
	height: 100%;
	object-fit: contain;
	object-position: center center;
	width: 100%;
}

.clf-category-card-placeholder {
	align-items: center;
	color: var(--clf-ink-soft);
	display: flex;
	height: 100%;
	justify-content: center;
	padding: 1rem;
	text-align: center;
}

.clf-category-card-copy {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}

.clf-category-card strong {
	font-family: "Fraunces", Georgia, serif;
	font-size: 1.4rem;
}

.clf-category-card-count {
	align-self: flex-start;
	background: var(--clf-highlight-soft);
	border-radius: 999px;
	color: var(--clf-ink-soft);
	font-size: 0.95rem;
	font-weight: 700;
	padding: 0.3rem 0.65rem;
}

.clf-button,
.clf-search-form button,
.clf-filter-actions .clf-button {
	border-radius: 999px;
	font-weight: 800;
}

.clf-button-primary {
	background: var(--clf-accent);
	border-color: var(--clf-accent);
	color: #fff;
}

.clf-button-primary:hover,
.clf-button-primary:focus {
	background: var(--clf-accent-strong);
	border-color: var(--clf-accent-strong);
	color: #fff;
}

.clf-button-secondary {
	background: rgba(255, 255, 255, 0.8);
	border-color: rgba(29, 95, 67, 0.18);
	color: var(--clf-accent-strong);
}

.clf-button:focus,
.clf-filter-grid input:focus,
.clf-filter-grid select:focus,
.clf-search-form input:focus {
	outline: 3px solid rgba(240, 197, 109, 0.8);
	outline-offset: 2px;
}

.clf-archive-shell .clf-filter-form,
.clf-archive-shell .clf-grid {
	margin-top: 0;
}

.clf-archive-hero {
	margin-bottom: 1.35rem;
}

.clf-archive-description p {
	margin-bottom: 0;
}

.clf-archive-art {
	align-self: stretch;
	border-radius: 28px;
	overflow: hidden;
}

.clf-single-page .clf-page-header,
.clf-download-landing .clf-page-header {
	background: linear-gradient(180deg, rgba(255, 253, 247, 0.96), rgba(250, 243, 234, 0.86));
	border: 1px solid var(--clf-border);
	border-radius: var(--clf-radius-xl);
	box-shadow: var(--clf-shadow);
	margin-bottom: 1.4rem;
	padding: 1.35rem;
}

.clf-single-page .clf-page-header h1,
.clf-download-landing .clf-page-header h1 {
	font-size: clamp(2.2rem, 4vw, 4rem);
	margin-bottom: 0.45rem;
}

.clf-single-columns,
.clf-download-columns {
	gap: 1.25rem;
}

.clf-single-main,
.clf-download-main,
.clf-single-sidebar,
.clf-download-sidebar {
	background: rgba(255, 253, 247, 0.82);
	border: 1px solid var(--clf-border);
	border-radius: var(--clf-radius-xl);
	box-shadow: var(--clf-shadow);
	padding: 1.2rem;
}

.clf-large-preview {
	background: linear-gradient(180deg, #f9f1e5, #fffefc);
	border-radius: 24px;
	box-shadow: inset 0 0 0 1px rgba(35, 48, 41, 0.08);
	margin-bottom: 1.2rem;
	height: auto;
	margin-left: auto;
	margin-right: auto;
	max-height: min(70vh, 800px);
	max-width: min(100%, 560px);
	object-fit: contain;
	width: auto;
}

.clf-browse-nav {
	align-items: center;
	background: rgba(255, 252, 247, 0.9);
	border: 1px solid rgba(35, 48, 41, 0.09);
	border-radius: 24px;
	display: grid;
	gap: 0.85rem;
	grid-template-columns: minmax(0, 1fr) auto;
	margin-bottom: 1.1rem;
	padding: 0.9rem;
}

.clf-browse-back {
	font-size: 0.92rem;
	font-weight: 800;
	text-decoration: none;
}

.clf-browse-position {
	background: var(--clf-highlight-soft);
	border-radius: 999px;
	color: var(--clf-ink-soft);
	font-size: 0.86rem;
	font-weight: 800;
	padding: 0.36rem 0.62rem;
}

.clf-browse-actions {
	display: grid;
	gap: 0.65rem;
	grid-column: 1 / -1;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.clf-browse-link {
	align-items: flex-start;
	border-radius: 18px;
	display: flex;
	flex-direction: column;
	gap: 0.22rem;
	justify-content: center;
	min-height: 4.8rem;
	text-align: left;
	white-space: normal;
}

.clf-browse-link span {
	font-size: 0.8rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.clf-browse-link strong {
	color: var(--clf-ink);
	font-family: "Fraunces", Georgia, serif;
	font-size: 1.05rem;
	letter-spacing: -0.02em;
	line-height: 1.12;
}

.clf-browse-link-next {
	align-items: flex-end;
	text-align: right;
}

.clf-browse-link.is-disabled {
	cursor: default;
	opacity: 0.42;
}

.clf-share-panel {
	align-items: center;
	background: rgba(255, 252, 247, 0.9);
	border: 1px solid rgba(35, 48, 41, 0.09);
	border-radius: 24px;
	display: flex;
	flex-wrap: wrap;
	gap: 0.9rem 1.15rem;
	justify-content: space-between;
	margin: 0 0 1.15rem;
	padding: 0.95rem;
}

.clf-share-panel__copy {
	display: flex;
	flex-direction: column;
	gap: 0.18rem;
	min-width: min(100%, 18rem);
}

.clf-share-panel__copy strong {
	font-family: "Fraunces", Georgia, serif;
	font-size: 1.25rem;
	letter-spacing: -0.02em;
}

.clf-share-panel__copy span {
	color: var(--clf-ink-soft);
	font-size: 0.92rem;
	font-weight: 700;
	line-height: 1.45;
}

.clf-share-panel__buttons,
.clf-share-panel .a2a_kit,
.clf-share-fallback {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.42rem;
}

.clf-share-panel .a2a_kit a,
.clf-share-fallback a {
	border-radius: 999px;
}

.clf-share-fallback a {
	background: rgba(255, 255, 255, 0.8);
	border: 1px solid rgba(29, 95, 67, 0.18);
	color: var(--clf-accent-strong);
	font-size: 0.9rem;
	font-weight: 800;
	padding: 0.48rem 0.7rem;
	text-decoration: none;
}

.clf-share-panel--article {
	margin-top: 1.1rem;
}

.clf-entry-copy,
.clf-supporting-copy,
.clf-license-notice,
.clf-affiliate-block,
.clf-metadata-panel,
.clf-download-cta {
	border-radius: 22px;
}

.clf-metadata-panel > div {
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid rgba(35, 48, 41, 0.07);
	border-radius: 18px;
	padding: 1rem 0.8rem;
}

.clf-metadata-panel strong {
	display: block;
	font-size: 0.9rem;
	letter-spacing: 0.08em;
	margin-bottom: 0.3rem;
	text-transform: uppercase;
}

.clf-metadata-panel span {
	color: var(--clf-ink-soft);
	font-weight: 700;
}

.clf-safe-note,
.clf-disclosure,
.clf-ad-slot-label {
	color: var(--clf-ink-soft);
}

.clf-affiliate-card img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

.clf-pagination a,
.clf-pagination span {
	background: rgba(255, 255, 255, 0.82);
	border-color: rgba(29, 95, 67, 0.2);
	color: var(--clf-accent-strong);
}

.clf-public-stats > div {
	border-radius: 20px;
	padding: 1rem;
}

.clf-public-stats strong {
	color: var(--clf-accent-strong);
	font-size: 2rem;
}

.clf-empty-state {
	background: rgba(255, 255, 255, 0.82);
	border: 1px dashed rgba(35, 48, 41, 0.2);
	border-radius: 20px;
	padding: 1.4rem;
}

@keyframes clfFloat {
	0%,
	100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-10px);
	}
}

@media (max-width: 1100px) {
	.clf-landing-hero,
	.clf-archive-hero,
	.clf-supplies-band,
	.clf-search-band,
	.clf-editorial-split {
		grid-template-columns: 1fr;
	}

	.clf-hero-card.is-offset {
		margin-left: 0;
	}

	.clf-editorial-panels {
		grid-template-columns: 1fr;
	}

	.clf-landing-benefits {
		grid-template-columns: 1fr;
	}

	.header-horizontal #header {
		display: block;
		padding-right: 5.2rem;
	}

	.header-horizontal.sidemenu-right,
	.header-horizontal.mobile-menu-visible.sidemenu-right {
		left: 0;
	}

	.header-horizontal .header-icons,
	.header-horizontal .header-icons.tf_hide {
		display: block;
		position: absolute;
		right: 0.35rem;
		top: 0.8rem;
		transform: none;
		z-index: 7;
	}

	.header-horizontal.mobile-menu-visible #headerwrap .header-icons,
	.header-horizontal.mobile-menu-visible #headerwrap .header-icons.tf_hide {
		display: block;
	}

	.header-horizontal #menu-icon {
		align-items: center;
		background: rgba(255, 255, 255, 0.82);
		border: 1px solid rgba(35, 48, 41, 0.1);
		border-radius: 999px;
		box-shadow: 0 10px 24px rgba(25, 33, 28, 0.08);
		display: inline-flex;
		justify-content: center;
		margin: 0;
		min-height: 42px;
		min-width: 42px;
		padding: 0;
	}

	.header-horizontal #menu-icon:hover,
	.header-horizontal #menu-icon:focus {
		background: rgba(255, 255, 255, 0.94);
	}

	.header-horizontal #menu-icon .menu-icon-inner {
		height: 16px;
		width: 20px;
	}

	.header-horizontal .clf-language-switcher-wrap {
		justify-content: flex-end;
		right: 3.85rem;
		top: 0.8rem;
	}

	.header-horizontal.sidemenu-right #headerwrap,
	.header-horizontal.sidemenu-right .fixed-header {
		left: 0;
	}

	.header-horizontal #mobile-menu.sidemenu,
	.header-horizontal #mobile-menu.sidemenu-off,
	.header-horizontal #mobile-menu.sidemenu-on {
		background: transparent;
		box-shadow: none;
		color: inherit;
		display: block;
		height: auto;
		max-height: 0;
		opacity: 0;
		overflow: hidden;
		padding: 0;
		position: static;
		right: auto;
		top: auto;
		transition: max-height 220ms ease, opacity 220ms ease, padding 220ms ease, visibility 220ms ease;
		visibility: hidden;
		width: 100%;
		z-index: auto;
	}

	.header-horizontal.mobile-menu-visible #mobile-menu.sidemenu-on {
		max-height: 75vh;
		opacity: 1;
		overflow: auto;
		padding: 0.85rem 0 0;
		visibility: visible;
	}

	.header-horizontal #menu-icon-close {
		display: none !important;
	}

	.header-horizontal #mobile-menu #main-nav-wrap {
		margin: 0;
	}

	.header-horizontal #mobile-menu #main-nav {
		align-items: stretch;
		display: block;
		gap: 0;
		margin: 0;
	}

	.header-horizontal #mobile-menu #main-nav li {
		float: none;
	}

	.header-horizontal #mobile-menu #main-nav a {
		background: transparent;
		border-radius: 0;
		display: block;
		padding: 0.75rem 0;
		transform: none;
		white-space: normal;
	}

	.header-horizontal #mobile-menu #main-nav a:hover,
	.header-horizontal #mobile-menu #main-nav a:focus {
		background: transparent;
		transform: none;
	}

	.header-horizontal #mobile-menu #main-nav .clf-nav-dropdown-parent .child-arrow,
	.header-horizontal #mobile-menu #main-nav .clf-category-dropdown-parent .child-arrow {
		margin-left: 0.2rem;
	}

	.header-horizontal #mobile-menu #main-nav > .clf-nav-dropdown-parent::after,
	.header-horizontal #mobile-menu #main-nav > .clf-category-dropdown-parent::after {
		content: none;
	}

	.header-horizontal #mobile-menu #main-nav .clf-nav-dropdown-parent > .sub-menu,
	.header-horizontal #mobile-menu #main-nav .clf-category-dropdown-parent > .sub-menu {
		background: rgba(255, 255, 255, 0.48);
		border: 0;
		border-left: 1px solid rgba(35, 48, 41, 0.1);
		border-radius: 0;
		box-shadow: none;
		display: block;
		margin: 0.1rem 0 0.4rem 0.8rem;
		max-height: none;
		min-width: 0;
		opacity: 1;
		overflow: visible;
		padding: 0 0 0 0.85rem;
		pointer-events: auto;
		position: static;
		transform: none;
		visibility: visible;
	}

	.header-horizontal #mobile-menu #main-nav .clf-category-dropdown-item > a {
		font-size: 0.92rem;
		padding: 0.52rem 0;
		white-space: normal;
	}
}

@media (max-width: 860px) {
	.clf-landing-shell,
	.clf-archive-shell,
	.clf-page {
		padding: 1.15rem 0.9rem 3rem;
	}

	.clf-landing-title {
		max-width: 100%;
	}

	.clf-section-header {
		align-items: start;
		flex-direction: column;
	}

	.clf-browse-nav {
		grid-template-columns: 1fr;
	}

	.clf-browse-position {
		justify-self: start;
	}

	.clf-browse-actions {
		grid-template-columns: 1fr;
	}

	.clf-browse-link-next {
		align-items: flex-start;
		text-align: left;
	}

	.clf-card-image {
		aspect-ratio: 4 / 5.5;
	}

	.clf-single-columns,
	.clf-download-columns {
		grid-template-columns: 1fr;
	}
}

/* Worker 2 refresh: connected flow, real-image emphasis, lighter card treatment */
:root {
	--clf-accent: #1f6a4a;
	--clf-accent-strong: #123f2d;
	--clf-highlight: #ddb769;
	--clf-highlight-soft: #fff5dd;
	--clf-surface: #fbf6ee;
	--clf-surface-strong: #efe3d3;
	--clf-ink: #203229;
	--clf-ink-soft: #56625a;
	--clf-border: rgba(39, 52, 44, 0.14);
	--clf-line: rgba(39, 52, 44, 0.12);
	--clf-shadow: 0 24px 60px rgba(26, 35, 29, 0.1);
	--clf-shadow-strong: 0 32px 80px rgba(26, 35, 29, 0.16);
	--clf-radius-xl: 36px;
	--clf-radius-lg: 28px;
	--clf-radius-md: 18px;
	--clf-max: 1240px;
}

body {
	background:
		radial-gradient(circle at top left, rgba(221, 183, 105, 0.22), transparent 25%),
		radial-gradient(circle at 88% 10%, rgba(177, 211, 188, 0.34), transparent 22%),
		linear-gradient(180deg, #fffdf8 0%, #f8f1e6 48%, #f6eee3 100%);
}

.clf-landing-shell,
.clf-archive-shell {
	max-width: var(--clf-max);
	padding: 0 1.35rem 4.5rem;
}

.clf-landing-shell > section:not(.clf-landing-hero),
.clf-archive-shell > section {
	margin-top: clamp(2rem, 4vw, 3.4rem);
}

.clf-landing-hero,
.clf-archive-hero {
	align-items: center;
	background:
		radial-gradient(circle at top left, rgba(221, 183, 105, 0.2), transparent 28%),
		linear-gradient(180deg, rgba(255, 252, 246, 0.98) 0%, rgba(246, 238, 226, 0.84) 100%);
	border: 0;
	border-bottom: 1px solid var(--clf-line);
	border-radius: 0;
	box-shadow: none;
	display: grid;
	gap: clamp(2rem, 4vw, 4rem);
	grid-template-columns: minmax(0, 1fr) minmax(320px, 0.92fr);
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding:
		clamp(2.8rem, 7vw, 6rem)
		max(1.35rem, calc((100vw - var(--clf-max)) / 2 + 1.35rem))
		clamp(2.4rem, 5vw, 4.5rem);
	width: 100vw;
}

.clf-landing-shell,
.clf-archive-shell,
.clf-page {
	max-width: calc(var(--clf-max) + (var(--clf-page-gutter) * 2));
	padding: clamp(2rem, 3vw, 2.8rem) var(--clf-page-gutter) clamp(4rem, 6vw, 5.5rem);
}

.clf-landing-hero,
.clf-archive-hero {
	align-items: start;
	gap: clamp(1.15rem, 2.2vw, 1.9rem);
	grid-template-columns: minmax(0, 1.04fr) minmax(280px, 28rem);
	padding: clamp(1.45rem, 2.3vw, 2rem);
}

.clf-landing-hero::before,
.clf-archive-hero::before {
	background: radial-gradient(circle at 72% 24%, rgba(31, 106, 74, 0.08), transparent 26%);
}

.clf-landing-hero::after,
.clf-archive-hero::after {
	background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.2) 100%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.clf-landing-hero.is-text-only,
.clf-archive-hero.is-text-only {
	grid-template-columns: minmax(0, 1fr);
}

.clf-landing-copy,
.clf-archive-copy {
	max-width: 38rem;
}

.clf-landing-title {
	font-size: clamp(2.55rem, 4.35vw, 4.2rem);
	line-height: 0.96;
	max-width: 11ch;
	text-wrap: balance;
}

.clf-archive-copy h1 {
	font-size: clamp(2.4rem, 4.8vw, 4.2rem);
	max-width: 9ch;
}

.clf-landing-intro,
.clf-archive-description,
.clf-search-band-copy p,
.clf-editorial-copy p,
.clf-supplies-copy p {
	font-size: 1.06rem;
	line-height: 1.75;
	max-width: 54ch;
}

.clf-landing-note {
	color: var(--clf-ink-soft);
	font-size: 0.95rem;
	line-height: 1.65;
	margin: 0;
	max-width: 46ch;
}

.clf-landing-actions {
	gap: 0.75rem;
	margin: 1.6rem 0 1rem;
}

.clf-landing-button,
.clf-button,
.clf-search-form button,
.clf-filter-actions .clf-button {
	border-width: 1px;
	box-shadow: none;
}

.clf-landing-button-primary,
.clf-button-primary {
	box-shadow: 0 14px 34px rgba(31, 106, 74, 0.22);
}

.clf-landing-benefits {
	gap: 0;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 1.8rem;
	max-width: 42rem;
}

.clf-benefit-card {
	background: none;
	border: 0;
	border-top: 1px solid var(--clf-line);
	border-radius: 0;
	box-shadow: none;
	padding: 1.1rem 1.15rem 1.1rem 0;
}

.clf-benefit-card:nth-child(even) {
	border-left: 1px solid var(--clf-line);
	padding-left: 1.15rem;
	padding-right: 0;
}

.clf-benefit-icon {
	background: transparent;
	border: 1px solid rgba(39, 52, 44, 0.14);
	height: 2.6rem;
	width: 2.6rem;
}

.clf-benefit-title {
	color: var(--clf-ink);
	font-family: "Plus Jakarta Sans", "Public Sans", "Segoe UI", sans-serif;
	font-size: 0.98rem;
	font-weight: 800;
	line-height: 1.25;
	margin: 0 0 0.25rem;
}

.clf-benefit-copy p:last-child {
	font-size: 0.92rem;
	line-height: 1.6;
}

.clf-shortcuts-band {
	border-top: 1px solid var(--clf-line);
	gap: 0.9rem 1.1rem;
	margin: 1.4rem 0 0;
	padding-top: 0.8rem;
}

.clf-shortcut-chip {
	background: none;
	border: 0;
	border-bottom: 1px solid rgba(39, 52, 44, 0.14);
	border-radius: 0;
	padding: 0.35rem 0;
}

.clf-landing-visual,
.clf-archive-visual {
	align-items: stretch;
	display: grid;
	gap: 0.8rem;
	grid-template-columns: minmax(0, 1fr) minmax(132px, 0.5fr);
	justify-self: end;
	max-width: 28rem;
	position: relative;
	width: 100%;
}

.clf-hero-primary,
.clf-archive-feature,
.clf-editorial-feature,
.clf-hero-secondary,
.clf-archive-secondary,
.clf-editorial-secondary,
.clf-supplies-preview {
	background: rgba(255, 255, 255, 0.62);
	border-radius: 30px;
	box-shadow: var(--clf-shadow-strong);
	color: #fff;
	display: block;
	overflow: hidden;
	position: relative;
	text-decoration: none;
}

.clf-hero-primary::after,
.clf-archive-feature::after,
.clf-editorial-feature::after,
.clf-hero-secondary::after,
.clf-archive-secondary::after,
.clf-editorial-secondary::after {
	background: linear-gradient(180deg, rgba(17, 25, 20, 0.05) 18%, rgba(17, 25, 20, 0.2) 58%, rgba(17, 25, 20, 0.74) 100%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.clf-hero-primary,
.clf-archive-feature {
	animation: clfReveal 0.8s ease both;
	min-height: clamp(330px, 35vw, 460px);
}

.clf-hero-rail,
.clf-archive-rail,
.clf-editorial-strip {
	display: grid;
	gap: 0.8rem;
	grid-template-rows: repeat(2, minmax(0, 1fr));
}

.clf-hero-secondary,
.clf-archive-secondary,
.clf-editorial-secondary {
	animation: clfReveal 1s ease both;
	min-height: 158px;
}

.clf-hero-secondary .clf-visual-caption {
	bottom: 0.75rem;
	left: 0.75rem;
	padding: 0.72rem 0.78rem;
	right: 0.75rem;
}

.clf-hero-secondary .clf-visual-caption strong {
	font-size: clamp(1rem, 1.1vw, 1.14rem);
}

.clf-hero-secondary:nth-child(2),
.clf-archive-secondary:nth-child(2),
.clf-editorial-secondary:nth-child(2) {
	animation-delay: 0.08s;
}

.clf-hero-primary img,
.clf-archive-feature img,
.clf-editorial-feature img,
.clf-hero-secondary img,
.clf-archive-secondary img,
.clf-editorial-secondary img,
.clf-supplies-preview img,
.clf-supplies-preview video {
	filter: saturate(102%);
	height: 100%;
	object-fit: cover;
	transform: scale(1.001);
	transition: filter 380ms ease, transform 380ms ease;
	width: 100%;
}

.clf-hero-primary:hover img,
.clf-hero-primary:focus img,
.clf-archive-feature:hover img,
.clf-archive-feature:focus img,
.clf-editorial-feature:hover img,
.clf-editorial-feature:focus img,
.clf-hero-secondary:hover img,
.clf-hero-secondary:focus img,
.clf-archive-secondary:hover img,
.clf-archive-secondary:focus img,
.clf-editorial-secondary:hover img,
.clf-editorial-secondary:focus img,
.clf-supplies-preview:hover img,
.clf-supplies-preview:focus img,
.clf-supplies-preview:hover video,
.clf-supplies-preview:focus video {
	filter: saturate(108%);
	transform: scale(1.04);
}

.clf-visual-caption {
	background: linear-gradient(180deg, rgba(17, 25, 20, 0.22), rgba(17, 25, 20, 0.88));
	border-radius: 24px;
	bottom: 1rem;
	display: block;
	left: 1rem;
	padding: 0.9rem 0.95rem;
	position: absolute;
	right: 1rem;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.36);
	z-index: 1;
}

.clf-visual-label {
	background: rgba(17, 25, 20, 0.34);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	display: inline-flex;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	margin-bottom: 0.4rem;
	padding: 0.3rem 0.65rem;
	text-transform: uppercase;
}

.clf-visual-caption strong {
	display: block;
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.25rem, 1.8vw, 1.75rem);
	line-height: 1.1;
}

.clf-visual-text {
	color: rgba(255, 255, 255, 0.92);
	display: block;
	font-size: 0.9rem;
	line-height: 1.55;
	margin-top: 0.45rem;
}

.clf-search-band {
	background: rgba(255, 251, 245, 0.82);
	backdrop-filter: blur(18px);
	border: 1px solid rgba(39, 52, 44, 0.11);
	border-radius: 32px;
	box-shadow: var(--clf-shadow);
	margin-top: var(--clf-section-gap);
	padding: 1.55rem clamp(1.35rem, 2vw, 1.8rem);
	position: relative;
	z-index: 3;
}

.clf-search-band .clf-search-form {
	align-items: end;
	display: grid;
	gap: 0.75rem;
	grid-template-columns: minmax(0, 1fr) auto;
	margin: 0;
}

.clf-search-band .clf-search-form label {
	margin: 0;
}

.clf-search-band .clf-search-form,
.clf-archive-controls .clf-filter-form {
	background: rgba(255, 252, 247, 0.84);
	border: 1px solid rgba(39, 52, 44, 0.11);
	border-radius: 28px;
	box-shadow: none;
	padding: 1.1rem 1.15rem;
}

.clf-editorial-split,
.clf-supplies-band,
.clf-section-shell,
.clf-stats-shell,
.clf-archive-controls,
.clf-archive-results {
	background: none;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	margin-top: var(--clf-section-gap);
	padding: 0;
	position: relative;
}

.clf-editorial-split,
.clf-supplies-band,
.clf-section-shell,
.clf-stats-shell,
.clf-archive-controls,
.clf-archive-results {
	border-top: 1px solid var(--clf-line);
	padding-top: clamp(1.75rem, 3vw, 2.6rem);
}

.clf-editorial-split {
	align-items: start;
	display: grid;
	gap: clamp(1.5rem, 3vw, 2.6rem);
	grid-template-columns: minmax(0, 0.92fr) minmax(300px, 1.08fr);
}

.clf-editorial-split.is-text-only {
	grid-template-columns: minmax(0, 1fr);
}

.clf-editorial-panels {
	border-top: 1px solid var(--clf-line);
	gap: clamp(1.1rem, 1.9vw, 1.7rem);
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	margin-top: clamp(1.6rem, 2.4vw, 2.1rem);
	padding-top: clamp(1.45rem, 2vw, 1.85rem);
}

.clf-editorial-panel {
	display: flex;
	flex-direction: column;
	gap: 0.7rem;
	min-height: 100%;
	padding: clamp(1.2rem, 1.8vw, 1.55rem);
}

.clf-editorial-panel h3 {
	font-size: clamp(1.35rem, 1.5vw, 1.65rem);
	line-height: 1.06;
	margin: 0;
	max-width: 12ch;
}

.clf-editorial-panel p {
	line-height: 1.72;
	margin: 0;
	max-width: 24ch;
}

.clf-editorial-media {
	display: grid;
	gap: 1rem;
	grid-template-columns: minmax(0, 1fr) minmax(140px, 0.48fr);
	justify-self: end;
	max-width: 34rem;
	width: 100%;
}

.clf-editorial-feature {
	min-height: 460px;
}

.clf-section-shell-soft {
	background: none;
}

.clf-section-header h2,
.clf-search-band h2,
.clf-editorial-copy h2,
.clf-supplies-copy h2 {
	max-width: 12ch;
}

.clf-landing-shell .clf-grid,
.clf-archive-shell .clf-grid {
	gap: clamp(1.25rem, 2vw, 1.8rem);
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.clf-landing-shell .clf-card,
.clf-archive-shell .clf-card {
	background: none;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	overflow: visible;
}

.clf-landing-shell .clf-card-image,
.clf-archive-shell .clf-card-image {
	aspect-ratio: 4 / 5.65;
	background: linear-gradient(180deg, #f5ead8, #fffef9);
	border-radius: 28px;
	box-shadow: 0 18px 48px rgba(26, 35, 29, 0.14);
}

.clf-landing-shell .clf-card-body,
.clf-archive-shell .clf-card-body {
	padding: 1rem 0 0;
}

.clf-landing-shell .clf-card-body h3,
.clf-archive-shell .clf-card-body h3 {
	font-size: 1.42rem;
	margin: 0 0 0.5rem;
}

.clf-landing-shell .clf-card-tags,
.clf-archive-shell .clf-card-tags {
	color: var(--clf-accent-strong);
	font-size: 0.83rem;
	letter-spacing: 0.12em;
	margin: 0 0 0.65rem;
	text-transform: uppercase;
}

.clf-landing-shell .clf-meta-list,
.clf-archive-shell .clf-meta-list {
	gap: 0.45rem;
	margin: 0 0 0.8rem;
}

.clf-landing-shell .clf-meta-list li,
.clf-archive-shell .clf-meta-list li {
	background: rgba(31, 106, 74, 0.08);
	border-radius: 999px;
	padding: 0.35rem 0.7rem;
}

.clf-landing-shell .clf-card-body p:last-of-type,
.clf-archive-shell .clf-card-body p:last-of-type {
	line-height: 1.7;
	margin-bottom: 0;
}

.clf-landing-shell .clf-card-actions,
.clf-archive-shell .clf-card-actions {
	gap: 0.6rem;
	margin-top: 1rem;
}

.clf-landing-shell .clf-empty-state,
.clf-archive-shell .clf-empty-state {
	background: rgba(255, 252, 247, 0.74);
	box-shadow: none;
}

.clf-landing-shell .clf-category-grid {
	gap: 1rem 1.25rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.clf-landing-shell .clf-category-card {
	background: rgba(255, 252, 246, 0.88);
	border: 1px solid rgba(39, 52, 44, 0.08);
	border-radius: 24px;
	box-shadow: none;
	padding: 0.95rem;
}

.clf-landing-shell .clf-category-card strong {
	font-size: 1.25rem;
}

.clf-landing-shell .clf-category-card-media {
	border-radius: 22px;
	box-shadow: 0 16px 40px rgba(27, 39, 32, 0.11);
}

.clf-landing-shell .clf-category-card-copy {
	padding: 0 0.15rem 0.1rem;
}

.clf-landing-shell .clf-category-card-count {
	color: var(--clf-accent-strong);
}

.clf-supplies-band {
	align-items: start;
	display: grid;
	gap: clamp(1.4rem, 3vw, 2.2rem);
	grid-template-columns: minmax(0, 0.82fr) minmax(240px, 0.6fr) minmax(0, 0.88fr);
}

.clf-supplies-band.is-text-only {
	grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
}

.clf-supplies-visual {
	background: none;
	border-radius: 0;
}

.clf-supplies-preview-grid {
	display: grid;
	gap: 1rem;
}

.clf-supplies-preview {
	min-height: 220px;
}

.clf-supplies-checklist {
	background: rgba(255, 252, 247, 0.72);
	border: 1px solid rgba(39, 52, 44, 0.11);
	border-radius: 24px;
	padding: clamp(1rem, 2vw, 1.4rem);
}

.clf-supplies-checklist h3 {
	color: var(--clf-ink);
	font-family: var(--clf-display-font);
	font-size: clamp(1.45rem, 2.4vw, 2rem);
	letter-spacing: -0.04em;
	margin: 0 0 0.8rem;
}

.clf-supplies-checklist ul {
	display: grid;
	gap: 0.7rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.clf-supplies-checklist li {
	color: var(--clf-ink-soft);
	line-height: 1.55;
	padding-left: 1.4rem;
	position: relative;
}

.clf-supplies-checklist li::before {
	background: var(--clf-accent, #1d5f43);
	border-radius: 999px;
	content: "";
	height: 0.45rem;
	left: 0.2rem;
	position: absolute;
	top: 0.6rem;
	width: 0.45rem;
}

.clf-archive-controls .clf-filter-form {
	margin: 0;
}

.clf-archive-shell .clf-filter-grid {
	display: grid;
	gap: 0.95rem 1rem;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.clf-archive-shell .clf-filter-actions {
	gap: 0.75rem;
	margin-top: 1rem;
}

.clf-archive-results {
	margin-top: calc(var(--clf-section-gap) - 0.4rem);
}

.clf-archive-shell.is-compact-taxonomy .clf-archive-controls {
	border-top: 0;
	margin-top: 0;
	padding-top: 0;
}

.clf-archive-shell.is-compact-taxonomy .clf-archive-results {
	margin-top: 1.4rem;
}

.clf-archive-shell.is-no-hero .clf-archive-controls {
	border-top: 0;
	margin-top: 0;
	padding-top: 0;
}

.clf-archive-shell.is-no-hero .clf-archive-results {
	margin-top: 1.4rem;
}

.clf-stats-shell .clf-public-stats {
	gap: 1rem 1.5rem;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.clf-stats-shell .clf-public-stats > div {
	background: none;
	border: 0;
	border-radius: 0;
	border-top: 1px solid var(--clf-line);
	padding: 1rem 0 0;
	text-align: left;
}

.clf-stats-shell .clf-public-stats strong {
	font-size: clamp(2rem, 4vw, 3rem);
	line-height: 1;
}

.clf-stats-shell .clf-public-stats span {
	color: var(--clf-ink-soft);
	font-weight: 700;
}

.clf-archive-shell .clf-pagination a,
.clf-archive-shell .clf-pagination span {
	background: rgba(255, 255, 255, 0.74);
	border: 1px solid rgba(31, 106, 74, 0.18);
}

@keyframes clfReveal {
	from {
		opacity: 0;
		transform: translateY(24px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (max-width: 1260px) {
	.clf-landing-hero {
		grid-template-columns: minmax(0, 1fr) minmax(250px, 23.5rem);
	}

	.clf-landing-title {
		font-size: clamp(2.4rem, 3.9vw, 3.75rem);
		max-width: 11.5ch;
	}

	.clf-landing-visual {
		max-width: 23.5rem;
	}
}

@media (max-width: 1100px) {
	.clf-landing-hero,
	.clf-archive-hero,
	.clf-editorial-split,
	.clf-supplies-band,
	.clf-supplies-band.is-text-only {
		grid-template-columns: 1fr;
	}

	.clf-landing-visual,
	.clf-archive-visual,
	.clf-editorial-media {
		grid-template-columns: 1fr;
	}

	.clf-hero-rail,
	.clf-archive-rail,
	.clf-editorial-strip {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		grid-template-rows: none;
	}

	.clf-hero-primary,
	.clf-archive-feature,
	.clf-editorial-feature {
		min-height: 380px;
	}
}

@media (max-width: 860px) {
	.clf-landing-shell,
	.clf-archive-shell {
		padding: 1rem var(--clf-page-gutter) 3rem;
	}

	.clf-landing-hero,
	.clf-archive-hero {
		padding: 1.5rem;
	}

	.clf-search-band {
		margin-top: 1.35rem;
		padding: 1.15rem;
	}

	.clf-search-band .clf-search-form {
		grid-template-columns: 1fr;
	}

	.clf-landing-benefits {
		grid-template-columns: 1fr;
	}

	.clf-benefit-card,
	.clf-benefit-card:nth-child(even) {
		border-left: 0;
		padding-left: 0;
		padding-right: 0;
	}

	.clf-editorial-panels,
	.clf-stats-shell .clf-public-stats,
	.clf-hero-rail,
	.clf-archive-rail,
	.clf-editorial-strip {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 620px) {
	.pagewidth {
		padding-inline: 1rem;
	}

	.clf-landing-title,
	.clf-archive-copy h1,
	.clf-section-header h2,
	.clf-search-band h2,
	.clf-editorial-copy h2,
	.clf-supplies-copy h2 {
		max-width: none;
	}

	.clf-visual-caption {
		left: 0.8rem;
		right: 0.8rem;
	}

	.clf-stats-shell .clf-public-stats {
		grid-template-columns: 1fr;
	}
}

@media (prefers-reduced-motion: reduce) {
	.clf-hero-primary,
	.clf-archive-feature,
	.clf-editorial-feature,
	.clf-hero-secondary,
	.clf-archive-secondary,
	.clf-editorial-secondary {
		animation: none;
	}

	.clf-hero-primary img,
	.clf-archive-feature img,
	.clf-editorial-feature img,
	.clf-hero-secondary img,
	.clf-archive-secondary img,
	.clf-editorial-secondary img,
	.clf-supplies-preview img,
	.clf-card-image img {
		transition: none;
	}
}

/* Homepage hero slider + related load more */
.clf-landing-shell > section.clf-hero-slider {
	margin-top: 0;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	max-width: 100vw;
	width: 100vw;
}

.clf-hero-slider {
	align-items: end;
	background: #f5efe3;
	border-bottom: 1px solid var(--clf-line);
	border-radius: 0;
	display: flex;
	min-height: clamp(32rem, 76vh, 44rem);
	overflow: hidden;
	position: relative;
	width: 100%;
}

.clf-hero-slider::before {
	background:
		linear-gradient(90deg, rgba(16, 24, 20, 0.82) 0%, rgba(16, 24, 20, 0.72) 24%, rgba(16, 24, 20, 0.48) 46%, rgba(16, 24, 20, 0.24) 68%, rgba(16, 24, 20, 0.34) 100%),
		linear-gradient(180deg, rgba(255, 248, 236, 0.08) 0%, rgba(19, 28, 23, 0.22) 100%);
	content: "";
	inset: 0;
	position: absolute;
	z-index: 1;
}

.clf-hero-slider::after {
	background: radial-gradient(circle at 14% 18%, rgba(255, 239, 196, 0.22), transparent 30%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 1;
}

.clf-hero-slider.is-empty {
	background:
		radial-gradient(circle at top left, rgba(220, 181, 102, 0.26), transparent 32%),
		linear-gradient(180deg, rgba(255, 252, 246, 0.98), rgba(241, 232, 217, 0.86));
}

.clf-hero-slider-media {
	inset: 0;
	position: absolute;
}

.clf-hero-slide {
	inset: 0;
	opacity: 0;
	position: absolute;
	transform: scale(1.035);
	transition: opacity 680ms ease, transform 1100ms ease;
}

.clf-hero-slide.is-active {
	opacity: 1;
	transform: scale(1);
}

.clf-hero-slide-image,
.clf-hero-slide-video {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.clf-hero-slider-overlay {
	color: #fffdf8;
	display: flex;
	flex-direction: column;
	gap: 0.95rem;
	justify-content: flex-end;
	margin: 0 auto;
	max-width: none;
	min-height: clamp(32rem, 76vh, 44rem);
	padding:
		clamp(1.75rem, 3vw, 2.9rem)
		max(1.35rem, calc((100vw - var(--clf-max)) / 2 + clamp(1.75rem, 4vw, 3.9rem)))
		clamp(2rem, 4vw, 3rem);
	position: relative;
	width: 100%;
	z-index: 2;
}

.clf-hero-slider .clf-kicker {
	color: rgba(255, 248, 236, 0.92);
	margin-bottom: 0;
	max-width: 42rem;
}

.clf-hero-slider-title {
	color: #fffaf0;
	font-size: clamp(3rem, 5.1vw, 5.4rem);
	line-height: 0.94;
	margin: 0;
	max-width: 10.8ch;
	text-wrap: balance;
}

.clf-hero-slider-intro {
	color: rgba(255, 249, 241, 0.9);
	font-size: clamp(1.02rem, 1.5vw, 1.14rem);
	line-height: 1.7;
	margin: 0;
	max-width: 39ch;
}

.clf-hero-slider .clf-landing-actions {
	align-self: flex-start;
	margin: 0.4rem 0 0;
	max-width: 42rem;
}

.clf-hero-slider .clf-landing-button-secondary {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.24);
	color: #fffaf0;
}

.clf-hero-slider .clf-landing-button-secondary:hover,
.clf-hero-slider .clf-landing-button-secondary:focus {
	color: #fffaf0;
}

.clf-hero-slider-nav {
	align-items: end;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: space-between;
	margin-top: 1rem;
	max-width: 46rem;
	width: min(100%, 46rem);
}

.clf-hero-slider-status {
	background: rgba(16, 24, 20, 0.42);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 22px;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	max-width: 22rem;
	padding: 0.8rem 0.95rem;
}

.clf-hero-slider-status-label {
	color: rgba(255, 246, 232, 0.72);
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.clf-hero-slider-status-title {
	color: #fffdf8;
	font-size: 1rem;
	line-height: 1.35;
}

.clf-hero-slider-controls {
	align-items: center;
	display: inline-flex;
	gap: 0.7rem;
}

.clf-hero-slider-button {
	align-items: center;
	background: rgba(17, 25, 20, 0.38);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	color: #fffaf0;
	cursor: pointer;
	display: inline-flex;
	font-size: 1.4rem;
	height: 2.8rem;
	justify-content: center;
	padding: 0;
	transition: background 180ms ease, transform 180ms ease;
	width: 2.8rem;
}

.clf-hero-slider-button:hover,
.clf-hero-slider-button:focus {
	background: rgba(17, 25, 20, 0.55);
	transform: translateY(-1px);
}

.clf-hero-slider-dots {
	display: inline-flex;
	gap: 0.5rem;
}

.clf-hero-slider-dot {
	background: rgba(255, 255, 255, 0.3);
	border: 0;
	border-radius: 999px;
	cursor: pointer;
	height: 0.72rem;
	padding: 0;
	transition: background 180ms ease, transform 180ms ease, width 180ms ease;
	width: 0.72rem;
}

.clf-hero-slider-dot:hover,
.clf-hero-slider-dot:focus {
	background: rgba(255, 255, 255, 0.55);
}

.clf-hero-slider-dot.is-active {
	background: #fffaf0;
	transform: scale(1.02);
	width: 2.1rem;
}

.clf-landing-shell > section.clf-hero-benefits-band {
	margin-top: 1.5rem;
}

.clf-hero-benefits-band {
	border-top: 1px solid var(--clf-line);
	padding-top: 1.15rem;
}

.clf-hero-benefits-band .clf-landing-benefits {
	gap: 1rem;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin: 0;
	max-width: none;
}

.clf-hero-benefits-band .clf-benefit-card,
.clf-hero-benefits-band .clf-benefit-card:nth-child(even) {
	background: rgba(255, 252, 247, 0.84);
	border: 1px solid rgba(39, 52, 44, 0.11);
	border-radius: 24px;
	border-top-width: 1px;
	border-left: 1px solid rgba(39, 52, 44, 0.11);
	box-shadow: none;
	min-height: 100%;
	padding: 1rem 1.05rem;
}

.clf-hero-benefits-band + .clf-origin-band,
.clf-origin-band + .clf-search-band {
	margin-top: clamp(1.75rem, 3vw, 2.4rem);
}

.clf-origin-band {
	align-items: center;
	border-bottom: 1px solid var(--clf-line);
	border-top: 1px solid var(--clf-line);
	display: grid;
	gap: clamp(1.25rem, 3vw, 2.6rem);
	grid-template-columns: minmax(0, 1.2fr) minmax(260px, 0.8fr);
	padding: clamp(1.6rem, 3vw, 2.6rem) 0;
}

.clf-origin-copy h2 {
	font-size: clamp(2rem, 4vw, 3.45rem);
	margin: 0 0 0.8rem;
	max-width: 12ch;
}

.clf-origin-copy > p,
.clf-origin-story p,
.clf-origin-support-note,
.clf-origin-card p {
	color: var(--clf-ink-soft);
	font-size: 1.03rem;
	line-height: 1.75;
	margin: 0;
}

.clf-origin-story {
	display: grid;
	gap: 0.85rem;
	margin-top: clamp(1rem, 2vw, 1.45rem);
	max-width: 48rem;
}

.clf-origin-story p:first-child {
	color: var(--clf-ink);
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.25rem, 2.1vw, 1.7rem);
	letter-spacing: -0.03em;
	line-height: 1.25;
}

.clf-origin-actions {
	display: flex;
	flex-wrap: wrap;
	margin-top: clamp(1.15rem, 2.6vw, 1.7rem);
}

.clf-origin-actions .clf-landing-button {
	margin-top: 0;
}

.clf-origin-support-note {
	border-left: 3px solid rgba(29, 95, 67, 0.24);
	margin-top: clamp(1rem, 2vw, 1.45rem);
	max-width: 46rem;
	padding-left: 1rem;
}

.clf-origin-card {
	background: linear-gradient(180deg, rgba(255, 252, 246, 0.82), rgba(246, 235, 219, 0.58));
	border: 1px solid rgba(39, 52, 44, 0.11);
	border-radius: 28px;
	display: grid;
	gap: 1rem;
	padding: clamp(1.15rem, 2vw, 1.65rem);
}

.clf-origin-card .clf-landing-button {
	margin-top: 1.15rem;
}

.clf-origin-media {
	border-radius: 24px;
	box-shadow: 0 18px 44px rgba(33, 29, 20, 0.16);
	margin: 0;
	min-height: 220px;
	overflow: hidden;
	position: relative;
}

.clf-origin-media::after {
	background: linear-gradient(180deg, transparent 30%, rgba(18, 27, 22, 0.62) 100%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
}

.clf-origin-media img,
.clf-origin-media video {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.clf-origin-media figcaption {
	bottom: 0.8rem;
	color: #fffaf0;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.1em;
	position: absolute;
	right: 0.9rem;
	text-transform: uppercase;
	z-index: 1;
}

.clf-newsletter-band {
	margin-top: clamp(1.75rem, 3vw, 2.4rem);
}

.clf-newsletter-card {
	align-items: center;
	background:
		radial-gradient(circle at 8% 8%, rgba(223, 178, 95, 0.24), transparent 22rem),
		linear-gradient(135deg, rgba(255, 252, 246, 0.96), rgba(240, 231, 214, 0.82));
	border: 1px solid rgba(39, 52, 44, 0.12);
	border-radius: 34px;
	box-shadow: 0 20px 50px rgba(28, 38, 33, 0.1);
	display: grid;
	gap: clamp(1.2rem, 3vw, 2.4rem);
	grid-template-columns: minmax(0, 0.92fr) minmax(300px, 1.08fr);
	overflow: hidden;
	padding: clamp(1.35rem, 3vw, 2.2rem);
	position: relative;
}

.clf-newsletter-card::after {
	background:
		linear-gradient(rgba(29, 95, 67, 0.08) 1px, transparent 1px),
		linear-gradient(90deg, rgba(29, 95, 67, 0.08) 1px, transparent 1px);
	background-size: 36px 36px;
	content: "";
	inset: 0;
	opacity: 0.32;
	pointer-events: none;
	position: absolute;
}

.clf-newsletter-copy,
.clf-newsletter-form {
	position: relative;
	z-index: 1;
}

.clf-newsletter-copy h2 {
	color: var(--clf-ink);
	font-family: var(--clf-display-font);
	font-size: clamp(2.2rem, 5vw, 4.4rem);
	letter-spacing: -0.065em;
	line-height: 0.92;
	margin: 0 0 1rem;
	max-width: 12ch;
	text-wrap: balance;
}

.clf-newsletter-copy p:not(.clf-kicker),
.clf-newsletter-consent {
	color: rgba(32, 55, 47, 0.74);
	font-size: 1.03rem;
	line-height: 1.75;
	margin: 0;
}

.clf-newsletter-form {
	background: rgba(255, 255, 255, 0.68);
	border: 1px solid rgba(39, 52, 44, 0.12);
	border-radius: 28px;
	display: grid;
	gap: 0.85rem;
	padding: clamp(1rem, 2.4vw, 1.55rem);
}

.clf-newsletter-form label {
	color: var(--clf-ink);
	font-size: 0.86rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.clf-newsletter-interest {
	border: 0;
	display: grid;
	gap: 0.65rem;
	margin: 0.2rem 0 0;
	padding: 0;
}

.clf-newsletter-interest legend {
	color: var(--clf-ink);
	font-size: 0.86rem;
	font-weight: 800;
	letter-spacing: 0.06em;
	margin: 0 0 0.15rem;
	padding: 0;
	text-transform: uppercase;
}

.clf-newsletter-interest-options {
	display: grid;
	gap: 0.55rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.clf-newsletter-interest-options label {
	align-items: center;
	background: rgba(255, 253, 248, 0.82);
	border: 1px solid rgba(39, 52, 44, 0.13);
	border-radius: 18px;
	cursor: pointer;
	display: flex;
	gap: 0.5rem;
	letter-spacing: 0;
	line-height: 1.35;
	padding: 0.75rem 0.8rem;
	text-transform: none;
	transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.clf-newsletter-interest-options label:has(input:checked) {
	border-color: rgba(29, 95, 67, 0.5);
	box-shadow: 0 10px 24px rgba(29, 95, 67, 0.12);
}

.clf-newsletter-interest-options label:hover,
.clf-newsletter-interest-options label:focus-within {
	border-color: rgba(29, 95, 67, 0.42);
	transform: translateY(-1px);
}

.clf-newsletter-interest-options input {
	accent-color: var(--clf-accent, #1d5f43);
	flex: 0 0 auto;
}

.clf-newsletter-interest-options span {
	color: var(--clf-ink);
	font-size: 0.9rem;
	font-weight: 800;
}

.clf-newsletter-fields {
	display: grid;
	gap: 0.7rem;
	grid-template-columns: minmax(0, 1fr) auto;
}

.clf-newsletter-fields input {
	background: #fffdf8;
	border: 1px solid rgba(39, 52, 44, 0.18);
	border-radius: 999px;
	color: var(--clf-ink);
	font: inherit;
	min-height: 3.25rem;
	padding: 0.85rem 1.05rem;
	width: 100%;
}

.clf-newsletter-fields input:focus {
	border-color: rgba(29, 95, 67, 0.52);
	box-shadow: 0 0 0 4px rgba(29, 95, 67, 0.12);
	outline: 0;
}

.clf-newsletter-fields button {
	appearance: none;
	background: var(--clf-accent, #1d5f43);
	border: 0;
	border-radius: 999px;
	color: #fffdf8;
	cursor: pointer;
	font-weight: 900;
	min-height: 3.25rem;
	padding: 0.85rem 1.25rem;
	box-shadow: 0 12px 26px rgba(29, 95, 67, 0.2);
	transition: background 180ms ease, transform 180ms ease;
	white-space: nowrap;
}

.clf-newsletter-fields button:hover,
.clf-newsletter-fields button:focus {
	background: var(--clf-accent-strong, #124632);
	transform: translateY(-1px);
}

.clf-newsletter-consent {
	font-size: 0.92rem;
}

.clf-newsletter-message {
	background: rgba(29, 95, 67, 0.1);
	border: 1px solid rgba(29, 95, 67, 0.18);
	border-radius: 18px;
	color: #174a36;
	font-weight: 800;
	line-height: 1.5;
	margin: 0;
	padding: 0.75rem 0.9rem;
}

.clf-newsletter-honeypot {
	height: 1px;
	left: -9999px;
	margin: 0;
	overflow: hidden;
	position: absolute;
	top: auto;
	width: 1px;
}

.entry-content .clf-story-page {
	margin-inline: auto;
	max-width: 820px;
}

.entry-content .clf-story-page h2 {
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	margin-top: clamp(2rem, 4vw, 3rem);
}

.entry-content .clf-story-page p {
	color: var(--clf-ink-soft);
	font-size: 1.07rem;
	line-height: 1.82;
}

.entry-content .clf-story-page .clf-story-lead {
	color: var(--clf-ink);
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1.65rem, 3vw, 2.45rem);
	letter-spacing: -0.025em;
	line-height: 1.18;
	margin-bottom: clamp(1.7rem, 3vw, 2.5rem);
}

.clf-media-bank-strip {
	align-items: end;
	border-block: 1px solid rgba(32, 55, 47, 0.14);
	display: grid;
	gap: clamp(1.2rem, 3vw, 2.2rem);
	grid-template-columns: minmax(0, 0.72fr) minmax(280px, 1.28fr);
	margin: clamp(2.2rem, 5vw, 3.8rem) auto;
	max-width: 76rem;
	padding-block: clamp(1.2rem, 3vw, 2.1rem);
	width: 100%;
}

.clf-media-bank-strip-copy {
	max-width: 29rem;
}

.clf-media-bank-strip-copy h2 {
	color: #19332b;
	font-family: var(--clf-display-font, "Fraunces", Georgia, serif);
	font-size: clamp(2rem, 4vw, 3.45rem);
	letter-spacing: -0.06em;
	line-height: 0.96;
	margin: 0;
}

.clf-media-bank-strip-copy p:not(.clf-kicker) {
	color: rgba(32, 55, 47, 0.72);
	font-size: 1rem;
	line-height: 1.7;
	margin: 1rem 0 0;
}

.clf-media-bank-strip-grid {
	display: grid;
	gap: clamp(0.7rem, 1.4vw, 1rem);
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.clf-media-bank-card {
	background: rgba(255, 252, 245, 0.7);
	border: 1px solid rgba(32, 55, 47, 0.12);
	border-radius: 28px;
	box-shadow: 0 20px 46px rgba(29, 38, 34, 0.11);
	display: block;
	min-height: clamp(13rem, 22vw, 20rem);
	overflow: hidden;
	position: relative;
	text-decoration: none;
}

.clf-media-bank-card figure {
	height: 100%;
	margin: 0;
	min-height: inherit;
	position: relative;
}

.clf-media-bank-card img,
.clf-media-bank-card video {
	display: block;
	height: 100%;
	object-fit: cover;
	transform: scale(1.001);
	transition: transform 700ms cubic-bezier(0.2, 0.7, 0.2, 1);
	width: 100%;
}

.clf-media-bank-card:hover img,
.clf-media-bank-card:focus-visible img,
.clf-media-bank-card:hover video,
.clf-media-bank-card:focus-visible video {
	transform: scale(1.075);
}

.clf-media-bank-card:focus-visible {
	outline: 3px solid rgba(240, 197, 109, 0.9);
	outline-offset: 4px;
}

.clf-media-bank-caption {
	background: rgba(25, 43, 36, 0.76);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 20px;
	bottom: 0.7rem;
	color: #fffaf0;
	left: 0.7rem;
	padding: 0.72rem 0.82rem;
	position: absolute;
	right: 0.7rem;
}

.clf-media-bank-caption span {
	display: block;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.clf-media-bank-caption strong {
	display: block;
	font-family: "Fraunces", Georgia, serif;
	font-size: clamp(1rem, 2vw, 1.28rem);
	letter-spacing: -0.035em;
	line-height: 1.02;
	margin-top: 0.24rem;
}

.clf-content-media-strip {
	margin-block: clamp(2.4rem, 6vw, 4rem);
}

.clf-blog-entry__content .clf-content-media-strip,
.entry-content .clf-content-media-strip {
	margin-inline: calc(50% - min(44vw, 38rem));
}

.clf-archive-media-strip {
	margin-top: clamp(1.4rem, 4vw, 2.6rem);
}

.clf-related-pages .clf-grid {
	margin-top: 1rem;
}

.clf-related-actions {
	display: flex;
	justify-content: center;
	margin-top: 1.35rem;
}

.clf-related-actions.is-hidden {
	display: none;
}

.clf-related-feedback {
	color: var(--clf-ink-soft);
	font-size: 0.92rem;
	line-height: 1.6;
	margin: 0.75rem 0 0;
	min-height: 1.5rem;
	text-align: center;
}

@media (max-width: 1100px) {
	.clf-media-bank-strip {
		align-items: start;
		grid-template-columns: 1fr;
	}

	.clf-media-bank-strip-copy {
		max-width: 42rem;
	}
}

@media (max-width: 720px) {
	.clf-media-bank-strip {
		margin-block: clamp(1.8rem, 7vw, 2.6rem);
	}

	.clf-media-bank-strip-grid {
		grid-template-columns: 1fr;
	}

	.clf-media-bank-card {
		min-height: 17rem;
	}

	.clf-blog-entry__content .clf-content-media-strip,
	.entry-content .clf-content-media-strip {
		margin-inline: 0;
	}
}

@media (max-width: 1100px) {
	.clf-hero-slider,
	.clf-hero-slider-overlay {
		min-height: 32rem;
	}

	.clf-hero-slider-title {
		font-size: clamp(2.55rem, 5vw, 4.15rem);
		max-width: 11ch;
	}

	.clf-hero-benefits-band .clf-landing-benefits {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.clf-origin-band {
		grid-template-columns: 1fr;
	}

	.clf-newsletter-card {
		grid-template-columns: 1fr;
	}

	.clf-origin-copy h2 {
		max-width: 16ch;
	}
}

@media (max-width: 860px) {
	.clf-landing-shell > section.clf-hero-slider {
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		width: 100vw;
	}

	.clf-hero-slider,
	.clf-hero-slider-overlay {
		min-height: 28rem;
	}

	.clf-hero-slider-overlay {
		padding: 1.35rem max(1rem, var(--clf-page-gutter)) 1.6rem;
	}

	.clf-hero-slider-title {
		font-size: clamp(2.2rem, 8vw, 3.4rem);
		max-width: 12ch;
	}

	.clf-hero-slider-nav {
		align-items: start;
		flex-direction: column;
	}

	.clf-hero-benefits-band .clf-landing-benefits {
		grid-template-columns: 1fr;
	}

	.clf-newsletter-card {
		border-radius: 26px;
	}

	.clf-newsletter-fields {
		grid-template-columns: 1fr;
	}

	.clf-newsletter-interest-options {
		grid-template-columns: 1fr;
	}

	.clf-newsletter-fields button {
		width: 100%;
	}
}

@media (prefers-reduced-motion: reduce) {
	.clf-hero-slide {
		transition: none;
	}

	.clf-hero-slider-button {
		transition: none;
	}

	.clf-media-bank-card img,
	.clf-media-bank-card video,
	.clf-blog-teaser__image,
	.clf-blog-teaser__media video {
		transition: none;
	}

	.clf-media-bank-card:hover img,
	.clf-media-bank-card:focus-visible img,
	.clf-media-bank-card:hover video,
	.clf-media-bank-card:focus-visible video,
	.clf-blog-teaser__link:hover .clf-blog-teaser__image,
	.clf-blog-teaser__link:focus-visible .clf-blog-teaser__image,
	.clf-blog-teaser__link:hover .clf-blog-teaser__media video,
	.clf-blog-teaser__link:focus-visible .clf-blog-teaser__media video {
		transform: none;
	}
}

.clf-blog-shell,
.clf-blog-single {
	background:
		radial-gradient(circle at 12% 8%, rgba(209, 159, 83, 0.16), transparent 34rem),
		linear-gradient(180deg, #fffaf0 0%, #f6efe2 100%);
	color: #20372f;
	min-height: 100vh;
	padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 4.5rem);
}

.clf-blog-shell {
	display: grid;
	gap: clamp(2.4rem, 5vw, 4.5rem);
}

.clf-blog-hero {
	margin-inline: auto;
	max-width: 76rem;
	width: 100%;
}

.clf-blog-hero h1,
.clf-blog-entry__header h1 {
	color: #19332b;
	font-family: var(--clf-display-font);
	font-size: clamp(3rem, 9vw, 6.8rem);
	letter-spacing: -0.07em;
	line-height: 0.88;
	margin: 0 0 1.25rem;
	max-width: 12ch;
}

.clf-blog-hero p,
.clf-blog-entry__lead {
	color: rgba(32, 55, 47, 0.78);
	font-size: clamp(1.05rem, 2vw, 1.28rem);
	line-height: 1.7;
	margin: 0;
	max-width: 48rem;
}

.clf-blog-cta,
.clf-blog-back,
.clf-blog-readmore {
	align-items: center;
	color: #1c6c49;
	display: inline-flex;
	font-weight: 800;
	gap: 0.45rem;
	text-decoration: none;
}

.clf-blog-cta {
	background: #1c6c49;
	border-radius: 999px;
	color: #fff;
	margin-top: 1.6rem;
	padding: 0.85rem 1.25rem;
}

.clf-blog-list {
	display: grid;
	gap: 0;
	margin-inline: auto;
	max-width: 76rem;
	width: 100%;
}

.clf-blog-teaser {
	border-top: 1px solid rgba(32, 55, 47, 0.16);
}

.clf-blog-teaser:last-child {
	border-bottom: 1px solid rgba(32, 55, 47, 0.16);
}

.clf-blog-teaser__link {
	align-items: center;
	display: grid;
	gap: clamp(1.1rem, 3vw, 2rem);
	grid-template-columns: minmax(220px, 0.72fr) minmax(0, 1.28fr);
	padding: clamp(1.6rem, 3vw, 2.4rem) 0;
	text-decoration: none;
}

.clf-blog-teaser__media {
	aspect-ratio: 4 / 3;
	background: rgba(255, 252, 245, 0.72);
	border: 1px solid rgba(32, 55, 47, 0.12);
	border-radius: 28px;
	box-shadow: 0 18px 44px rgba(29, 38, 34, 0.1);
	margin: 0;
	overflow: hidden;
	position: relative;
}

.clf-blog-teaser__image,
.clf-blog-teaser__media video {
	display: block;
	height: 100%;
	object-fit: cover;
	transform: scale(1.001);
	transition: transform 700ms cubic-bezier(0.2, 0.7, 0.2, 1);
	width: 100%;
}

.clf-blog-teaser__copy {
	display: grid;
	gap: 0.75rem;
}

.clf-blog-teaser__link:hover .clf-blog-teaser__image,
.clf-blog-teaser__link:focus-visible .clf-blog-teaser__image,
.clf-blog-teaser__link:hover .clf-blog-teaser__media video,
.clf-blog-teaser__link:focus-visible .clf-blog-teaser__media video {
	transform: scale(1.06);
}

.clf-blog-teaser__meta,
.clf-blog-entry__meta {
	color: rgba(32, 55, 47, 0.58);
	font-size: 0.84rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.clf-blog-teaser h2 {
	color: #19332b;
	font-family: var(--clf-display-font);
	font-size: clamp(2rem, 4vw, 3.3rem);
	letter-spacing: -0.06em;
	line-height: 0.95;
	margin: 0;
	max-width: 14ch;
}

.clf-blog-teaser p {
	color: rgba(32, 55, 47, 0.74);
	font-size: 1.03rem;
	line-height: 1.65;
	margin: 0;
	max-width: 44rem;
}

.clf-blog-readmore {
	margin-top: 0.2rem;
}

.clf-blog-teaser__link:hover h2,
.clf-blog-teaser__link:focus-visible h2,
.clf-blog-back:hover,
.clf-blog-back:focus-visible,
.clf-blog-readmore:hover,
.clf-blog-readmore:focus-visible {
	color: #0d4f35;
}

.clf-blog-pagination {
	margin-inline: auto;
	max-width: 76rem;
	width: 100%;
}

.clf-blog-pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.clf-blog-pagination a,
.clf-blog-pagination span {
	border: 1px solid rgba(32, 55, 47, 0.22);
	border-radius: 999px;
	color: #20372f;
	display: inline-flex;
	font-weight: 800;
	min-width: 2.75rem;
	padding: 0.7rem 1rem;
	text-decoration: none;
}

.clf-blog-pagination .current {
	background: #20372f;
	color: #fff;
}

.clf-blog-entry {
	margin-inline: auto;
	max-width: 52rem;
	width: 100%;
}

.clf-blog-entry__header {
	margin-bottom: clamp(2rem, 5vw, 4rem);
}

.clf-blog-back {
	margin-bottom: 1.4rem;
}

.clf-blog-entry__meta {
	margin: 0 0 0.8rem;
}

.clf-blog-entry__content {
	color: rgba(32, 55, 47, 0.84);
	font-size: clamp(1.07rem, 1.4vw, 1.2rem);
	line-height: 1.82;
}

.clf-blog-entry__content > * + * {
	margin-top: 1.2rem;
}

.clf-blog-entry__content h2 {
	color: #19332b;
	font-family: var(--clf-display-font);
	font-size: clamp(2rem, 4vw, 3.2rem);
	letter-spacing: -0.05em;
	line-height: 1;
	margin-top: clamp(2.5rem, 6vw, 4rem);
}

.clf-blog-entry__content a {
	color: #1c6c49;
	font-weight: 800;
	text-decoration-thickness: 0.1em;
	text-underline-offset: 0.22em;
}

.clf-blog-entry__content .clf-button {
	text-decoration: none;
}

.clf-blog-entry__content .clf-button-primary,
.clf-blog-entry__content .clf-button-primary:visited {
	color: #fff;
}

.clf-blog-entry__content .clf-button-primary:hover,
.clf-blog-entry__content .clf-button-primary:focus {
	color: #fff;
}

.clf-blog-entry__content .clf-button-secondary,
.clf-blog-entry__content .clf-button-secondary:visited {
	color: var(--clf-accent-strong);
}

.clf-blog-entry__content ul,
.clf-blog-entry__content ol {
	padding-left: 1.2rem;
}

.clf-blog-entry__content li + li {
	margin-top: 0.55rem;
}

.clf-blog-entry__content .clf-shortcode-wrap {
	margin: clamp(1.8rem, 5vw, 3rem) calc(50% - min(44vw, 38rem));
}

.clf-blog-entry__image {
	aspect-ratio: 16 / 9;
	background: rgba(255, 252, 245, 0.72);
	border: 1px solid rgba(32, 55, 47, 0.12);
	border-radius: 32px;
	box-shadow: 0 24px 58px rgba(29, 38, 34, 0.12);
	margin: clamp(1.6rem, 4vw, 2.6rem) 0 clamp(1.6rem, 4vw, 2.8rem);
	max-height: 30rem;
	overflow: hidden;
}

.clf-blog-entry__image-file,
.clf-blog-entry__image video {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

@media (max-width: 760px) {
	.clf-blog-teaser__link {
		grid-template-columns: 1fr;
	}

	.clf-blog-teaser__media {
		aspect-ratio: 16 / 10;
		border-radius: 24px;
	}

	.clf-blog-hero h1,
	.clf-blog-entry__header h1 {
		font-size: clamp(2.6rem, 14vw, 4.8rem);
	}

	.clf-blog-entry__content .clf-shortcode-wrap {
		margin-inline: 0;
	}
}

.clf-search-results-shell {
	background:
		radial-gradient(circle at 90% 10%, rgba(28, 108, 73, 0.12), transparent 32rem),
		linear-gradient(180deg, #fffaf0 0%, #f6efe2 100%);
	color: #20372f;
	min-height: 100vh;
	padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 4.5rem);
}

.clf-search-results-header,
.clf-search-results-list,
.clf-search-empty {
	margin-inline: auto;
	max-width: 76rem;
	width: 100%;
}

.clf-search-results-header h1 {
	color: #19332b;
	font-family: var(--clf-display-font);
	font-size: clamp(2.7rem, 7vw, 5.6rem);
	letter-spacing: -0.07em;
	line-height: 0.92;
	margin: 0 0 1.5rem;
	max-width: 13ch;
}

.clf-search-results-form {
	background: rgba(255, 252, 247, 0.84);
	border: 1px solid rgba(32, 55, 47, 0.14);
	border-radius: 999px;
	display: flex;
	gap: 0.55rem;
	max-width: 42rem;
	padding: 0.45rem;
}

.clf-search-results-form input {
	background: transparent;
	border: 0;
	color: #20372f;
	flex: 1;
	font: inherit;
	min-width: 0;
	padding: 0.85rem 1rem;
}

.clf-search-results-form button {
	background: #1c6c49;
	border: 0;
	border-radius: 999px;
	color: #fff;
	font-weight: 800;
	padding: 0.85rem 1.25rem;
}

.clf-search-results-list {
	display: grid;
	gap: 0;
	margin-top: clamp(2rem, 5vw, 4rem);
}

.clf-search-result {
	border-top: 1px solid rgba(32, 55, 47, 0.16);
}

.clf-search-result:last-child {
	border-bottom: 1px solid rgba(32, 55, 47, 0.16);
}

.clf-search-result a {
	display: grid;
	gap: 0.75rem;
	padding: clamp(1.4rem, 3vw, 2.2rem) 0;
	text-decoration: none;
}

.clf-search-result span {
	color: rgba(32, 55, 47, 0.58);
	font-size: 0.82rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.clf-search-result h2 {
	color: #19332b;
	font-family: var(--clf-display-font);
	font-size: clamp(1.8rem, 4vw, 3rem);
	letter-spacing: -0.05em;
	line-height: 1;
	margin: 0;
}

.clf-search-result p,
.clf-search-empty p {
	color: rgba(32, 55, 47, 0.74);
	font-size: 1.03rem;
	line-height: 1.65;
	margin: 0;
	max-width: 48rem;
}

.clf-search-empty {
	margin-top: clamp(2rem, 5vw, 4rem);
}

.clf-search-empty h2 {
	color: #19332b;
	font-family: var(--clf-display-font);
	font-size: clamp(2.1rem, 5vw, 3.8rem);
	letter-spacing: -0.05em;
	line-height: 1;
	margin: 0 0 1rem;
}

@media (max-width: 640px) {
	.clf-search-results-form {
		align-items: stretch;
		border-radius: 28px;
		flex-direction: column;
	}
}
