/*
Theme Name: PocketSync Blog
Theme URI: https://example.com/pocketsync-blog
Author: PocketSync
Author URI: https://example.com
Description: A clean responsive WordPress blog theme with a soft landing page, Material Icons, featured cards, categories, newsletter, and teal/sage styling.
Version: 3.0.9
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pocketsync-blog
Tags: blog, custom-logo, featured-images, responsive-layout
*/

:root {
	--teal: #358991;
	--sage: #83aa8e;
	--olive: #c8d59f;
	--cream: #eef3d6;
	--paper: #fffaf7;
	--ink: #142631;
	--muted: #66737d;
	--line: rgba(131, 170, 142, 0.28);
	--shadow: 0 18px 48px rgba(23, 58, 63, 0.1);
	--shadow-strong: 0 24px 70px rgba(23, 58, 63, 0.16);
	--font-body: "Manrope", "Segoe UI", sans-serif;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	background:
		radial-gradient(circle at 88% 6%, rgba(200, 213, 159, 0.18), transparent 28rem),
		linear-gradient(180deg, #fffafd 0%, #fbfaf7 62%, #f2f5dc 100%);
	color: var(--ink);
	display: flex;
	flex-direction: column;
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.65;
	margin: 0;
	min-height: 100vh;
}

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

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

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

.container {
	margin-inline: auto;
	max-width: 1680px;
	padding-inline: clamp(64px, 7vw, 140px);
	width: 100%;
}

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
	width: 1px;
}

.skip-link:focus {
	background: var(--teal);
	border-radius: 10px;
	clip: auto;
	clip-path: none;
	color: #fff;
	font-weight: 800;
	height: auto;
	left: 18px;
	padding: 10px 14px;
	top: 18px;
	width: auto;
	z-index: 1000;
}

.site-main {
	flex: 1 0 auto;
}

.site-main.about-page,
.site-main.categories-page,
.site-main.archive-sustainability-page {
	padding-top: 34px;
}

.material-icons {
	font-size: 22px;
	line-height: 1;
}

.site-header {
	background: rgba(255, 250, 253, 0.92);
	backdrop-filter: blur(18px);
	position: sticky;
	top: 0;
	z-index: 50;
}

body.admin-bar .site-header {
	top: 32px;
}

.header-inner {
	align-items: center;
	display: grid;
	gap: 28px;
	grid-template-columns: minmax(160px, 1fr) auto minmax(160px, 1fr) auto;
	min-height: 86px;
}

.site-branding {
	align-items: center;
	display: flex;
	gap: 12px;
}

.site-logo-mark {
	display: none;
}

.site-title {
	color: var(--teal);
	font-size: clamp(1.8rem, 2.4vw, 2.35rem);
	font-weight: 900;
	letter-spacing: -0.05em;
}

.primary-navigation {
	justify-self: center;
}

.primary-navigation ul {
	align-items: center;
	display: flex;
	gap: clamp(26px, 3vw, 48px);
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-navigation a {
	color: var(--ink);
	font-size: 0.96rem;
	font-weight: 800;
	position: relative;
}

.primary-navigation a:hover,
.primary-navigation a:focus,
.primary-navigation .current-menu-item > a,
body.home .primary-navigation ul > li:first-child > a,
body.blog .primary-navigation ul > li:first-child > a,
body.page-template-page-categories .primary-navigation ul > li:nth-child(2) > a,
body.page-slug-categories .primary-navigation ul > li:nth-child(2) > a,
body.page-template-page-about .primary-navigation ul > li:nth-child(3) > a,
body.page-slug-about .primary-navigation ul > li:nth-child(3) > a,
body.page-template-page-contact .primary-navigation ul > li:nth-child(4) > a,
body.page-slug-contact .primary-navigation ul > li:nth-child(4) > a {
	color: var(--teal);
}

.primary-navigation .current-menu-item > a::after,
body.home .primary-navigation ul > li:first-child > a::after,
body.blog .primary-navigation ul > li:first-child > a::after,
body.page-template-page-categories .primary-navigation ul > li:nth-child(2) > a::after,
body.page-slug-categories .primary-navigation ul > li:nth-child(2) > a::after,
body.page-template-page-about .primary-navigation ul > li:nth-child(3) > a::after,
body.page-slug-about .primary-navigation ul > li:nth-child(3) > a::after,
body.page-template-page-contact .primary-navigation ul > li:nth-child(4) > a::after,
body.page-slug-contact .primary-navigation ul > li:nth-child(4) > a::after {
	background: var(--teal);
	border-radius: 999px;
	bottom: -12px;
	content: "";
	height: 3px;
	left: 0;
	position: absolute;
	right: 0;
}

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

.header-search {
	display: none;
}

.subscribe-link {
	background: var(--teal);
	border-radius: 12px;
	box-shadow: var(--shadow);
	color: #fff;
	font-weight: 900;
	padding: 15px 24px;
}

.subscribe-link:hover,
.subscribe-link:focus {
	background: var(--ink);
	color: #fff;
}

.header-search-link {
	align-items: center;
	color: var(--ink);
	display: inline-flex;
	height: 44px;
	justify-content: center;
	width: 44px;
}

.header-search-link .material-icons {
	font-size: 30px;
}

.header-search-link:hover,
.header-search-link:focus {
	color: var(--teal);
}

.menu-toggle {
	align-items: center;
	background: transparent;
	border: 0;
	color: var(--ink);
	cursor: pointer;
	display: inline-flex;
	height: 44px;
	justify-content: center;
	width: 44px;
}

.menu-toggle .material-icons {
	font-size: 34px;
}

.hero-section {
	padding: clamp(42px, 6vw, 78px) 0 28px;
}

.hero-section .container,
.posts-section .container {
	max-width: 1380px;
	padding-inline: clamp(32px, 5vw, 82px);
}

.hero-grid {
	align-items: center;
	display: grid;
	gap: clamp(42px, 6vw, 72px);
	grid-template-columns: minmax(390px, 560px) minmax(500px, 680px);
	justify-content: space-between;
}

.hero-copy {
	max-width: 560px;
}

.eyebrow {
	align-items: center;
	background: rgba(53, 137, 145, 0.12);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	font-size: 0.84rem;
	font-weight: 900;
	gap: 8px;
	margin: 0 0 22px;
	padding: 7px 16px;
}

.hero-title {
	color: var(--ink);
	font-size: clamp(3rem, 5.6vw, 5.2rem);
	font-weight: 900;
	letter-spacing: -0.065em;
	line-height: 1.08;
	margin: 0;
}

.hero-text {
	color: var(--muted);
	font-size: clamp(1rem, 1.4vw, 1.16rem);
	margin: 22px 0 0;
	max-width: 520px;
}

.hero-actions {
	display: grid;
	gap: 18px;
	grid-template-columns: minmax(250px, 1fr) auto;
	margin-top: 32px;
	max-width: 540px;
}

.hero-search {
	align-items: center;
	background: #fff;
	border: 1px solid rgba(131, 170, 142, 0.12);
	border-radius: 10px;
	box-shadow: var(--shadow);
	color: var(--ink);
	display: flex;
	gap: 10px;
	padding: 0 16px;
}

.hero-search input {
	background: transparent;
	border: 0;
	color: var(--ink);
	font: inherit;
	outline: 0;
	padding: 16px 0;
	width: 100%;
}

.button-primary,
.button-secondary {
	align-items: center;
	border-radius: 10px;
	display: inline-flex;
	font-weight: 900;
	gap: 10px;
	justify-content: center;
	padding: 15px 22px;
}

.button-primary {
	background: var(--teal);
	box-shadow: var(--shadow);
	color: #fff;
}

.button-primary:hover,
.button-primary:focus {
	background: var(--ink);
	color: #fff;
}

.button-secondary {
	border: 1px solid var(--line);
	color: var(--ink);
}

.hero-card {
	background: #eef3ec;
	border: 1px solid rgba(255, 255, 255, 0.78);
	border-radius: 72px;
	box-shadow:
		0 34px 70px rgba(23, 58, 63, 0.22),
		0 12px 22px rgba(23, 58, 63, 0.12),
		inset 0 1px 0 rgba(255, 255, 255, 0.9);
	justify-self: end;
	min-height: 360px;
	overflow: hidden;
	position: relative;
	transform: perspective(1200px) rotateX(0.6deg) rotateY(-2deg);
	width: min(100%, 680px);
}

.hero-card::after {
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.38), transparent 42%);
	border-radius: inherit;
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	z-index: 1;
}

.hero-card img {
	height: 100%;
	min-height: 360px;
	object-fit: cover;
	object-position: center;
	position: relative;
	width: 100%;
}

.posts-section,
.categories-section {
	padding: 34px 0;
}

.section-heading {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-bottom: 20px;
}

.section-heading h2,
.section-heading .eyebrow {
	background: transparent;
	border-radius: 0;
	letter-spacing: 0.12em;
	margin: 0;
	padding: 0;
	text-transform: uppercase;
}

.section-icon-image {
	border-radius: 8px;
	display: inline-block;
	height: 64px;
	object-fit: cover;
	width: 64px;
}

.section-heading a {
	color: var(--ink);
	font-size: 0.92rem;
	font-weight: 900;
}

.post-grid {
	display: grid;
	gap: 26px;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	justify-content: start;
}

.post-grid .blog-card {
	max-width: 420px;
}

.blog-card,
.category-card {
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(131, 170, 142, 0.18);
	border-radius: 14px;
	box-shadow: var(--shadow);
	overflow: hidden;
	transition: transform 180ms ease, box-shadow 180ms ease;
}

.blog-card {
	min-width: 0;
	overflow-wrap: anywhere;
	width: 100%;
}

.blog-card:hover,
.category-card:hover {
	box-shadow: 0 24px 62px rgba(23, 58, 63, 0.16);
	transform: translateY(-5px);
}

.blog-card-image {
	background: linear-gradient(135deg, var(--cream), var(--olive), var(--sage));
	display: block;
	height: 210px;
	overflow: hidden;
}

.blog-card-image img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.blog-card-art {
	align-items: center;
	background:
		radial-gradient(circle at 70% 28%, rgba(255, 255, 255, 0.72), transparent 78px),
		linear-gradient(135deg, rgba(238, 243, 214, 0.92), rgba(131, 170, 142, 0.72), rgba(53, 137, 145, 0.72));
	display: flex;
	height: 100%;
	justify-content: center;
	width: 100%;
}

.blog-card-art .material-icons {
	background: rgba(255, 255, 255, 0.72);
	border-radius: 999px;
	color: var(--teal);
	font-size: 58px;
	padding: 22px;
}

.blog-card-body {
	padding: 20px 22px 22px;
}

.post-category {
	background: rgba(131, 170, 142, 0.22);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	font-size: 0.76rem;
	font-weight: 900;
	padding: 5px 11px;
}

.blog-card h2 {
	font-size: 1.18rem;
	font-weight: 900;
	letter-spacing: -0.03em;
	line-height: 1.25;
	margin: 14px 0 10px;
	overflow-wrap: anywhere;
}

.blog-card-excerpt,
.post-meta {
	color: var(--muted);
	font-size: 0.92rem;
}

.blog-card-excerpt {
	display: -webkit-box;
	line-clamp: 3;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	line-height: 1.65;
	max-height: calc(1.65em * 3);
	overflow-wrap: anywhere;
	overflow: hidden;
	text-overflow: ellipsis;
	word-break: break-word;
}

.post-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 18px;
}

.post-meta span {
	align-items: center;
	display: inline-flex;
	gap: 6px;
}

.post-meta .material-icons {
	font-size: 18px;
}

.categories-section .container {
	margin-inline: auto;
	max-width: 1680px;
	width: 100%;
}

.category-grid {
	display: grid;
	gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
	justify-content: stretch;
	margin-inline: auto;
	width: 100%;
}

.categories-section .section-heading {
	align-items: center;
	display: flex;
	justify-content: center;
	margin-inline: 0;
	text-align: center;
	width: 100%;
}

.categories-section .section-heading .eyebrow {
	align-items: center;
	display: inline-flex;
	gap: 10px;
	justify-content: center;
	margin-inline: auto;
	width: auto;
}

.category-card {
	align-items: center;
	color: var(--ink);
	display: grid;
	justify-items: center;
	min-height: 150px;
	padding: 22px 12px;
	text-align: center;
	width: 100%;
}

.category-icon {
	align-items: center;
	background: var(--teal);
	border-radius: 999px;
	color: #fff;
	display: inline-flex;
	height: 66px;
	justify-content: center;
	width: 66px;
}

.category-card:nth-child(3n + 2) .category-icon {
	background: var(--sage);
}

.category-card:nth-child(3n) .category-icon {
	background: var(--olive);
	color: var(--ink);
}

.category-icon .material-icons {
	font-size: 46px;
	line-height: 1;
}

.category-card strong {
	margin-top: 12px;
}

.category-card > span:last-child {
	color: var(--muted);
	font-size: 0.9rem;
}

.newsletter-section {
	padding: 34px 0 58px;
}

.about-hero-section {
	padding: 0 0 28px;
}

.about-hero-section .container,
.about-stats-section .container {
	max-width: 1440px;
	padding-inline: clamp(42px, 6vw, 96px);
}

.about-hero {
	align-items: center;
	background: rgba(255, 255, 255, 0.36);
	border-radius: 32px;
	display: grid;
	gap: clamp(44px, 6vw, 108px);
	grid-template-columns: minmax(390px, 0.78fr) minmax(560px, 1.22fr);
	margin-inline: auto;
	min-height: 430px;
	padding: clamp(48px, 5vw, 78px) clamp(20px, 2.5vw, 34px);
	width: 100%;
}

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

.about-pill {
	background: rgba(53, 137, 145, 0.16);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: 900;
	margin-bottom: 18px;
	padding: 4px 12px;
}

.about-hero h1 {
	font-size: clamp(3rem, 4.7vw, 5rem);
	font-weight: 900;
	letter-spacing: -0.055em;
	line-height: 1.12;
	margin: 0;
}

.about-hero p {
	color: #354b5a;
	font-size: 1.1rem;
	line-height: 1.78;
	margin: 20px 0 0;
	max-width: 560px;
}

.about-button {
	align-items: center;
	background: var(--teal);
	border-radius: 10px;
	box-shadow: var(--shadow);
	color: #fff;
	display: inline-flex;
	font-weight: 900;
	gap: 10px;
	justify-content: center;
	margin-top: 26px;
	padding: 14px 22px;
}

.about-button:hover,
.about-button:focus {
	background: var(--ink);
	color: #fff;
}

.about-button .material-icons {
	font-size: 20px;
}

.about-button-small {
	font-size: 0.86rem;
	margin-top: 20px;
	padding: 12px 18px;
}

.about-hero-image {
	isolation: isolate;
	position: relative;
}

.about-hero-image::after {
	background: var(--olive);
	border-radius: 38px;
	bottom: -2px;
	content: "";
	height: 216px;
	position: absolute;
	right: -30px;
	width: 148px;
	z-index: -1;
}

.about-hero-image img {
	border-radius: 120px 26px 90px 26px;
	box-shadow: 0 16px 34px rgba(23, 58, 63, 0.06);
	height: 350px;
	object-fit: cover;
	width: 100%;
}

.about-stats-section {
	padding: 0 0 34px;
}

.about-stats {
	background: linear-gradient(135deg, rgba(224, 235, 226, 0.96), rgba(232, 239, 232, 0.95));
	border-radius: 24px;
	display: grid;
	grid-template-columns: minmax(0, 1.02fr) minmax(0, 1.12fr) minmax(0, 1.12fr) minmax(0, 1fr);
	margin-inline: auto;
	min-height: 222px;
	padding: 42px clamp(42px, 4vw, 72px);
	width: 100%;
}

.about-stat {
	align-items: flex-start;
	display: grid;
	gap: 20px;
	grid-template-columns: 84px minmax(0, 1fr);
	padding: 0 46px 0 0;
	position: relative;
}

.about-stat + .about-stat {
	border-left: 0;
	padding-left: 46px;
}

.about-stat:not(:last-child)::after {
	background: rgba(131, 170, 142, 0.3);
	bottom: 6px;
	content: "";
	position: absolute;
	right: 0;
	top: 6px;
	width: 1px;
}

.about-stat > div {
	min-width: 0;
}

.about-stat-icon {
	align-items: center;
	background: #fff;
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	height: 84px;
	justify-content: center;
	position: relative;
	width: 84px;
}

.about-stat-icon svg {
	display: block;
	height: 36px;
	left: 50%;
	position: absolute;
	stroke: currentColor;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 2;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 36px;
}

.about-stat-icon svg * {
	stroke: var(--teal);
}

.about-stat strong {
	display: block;
	font-size: clamp(1.95rem, 2.4vw, 2.45rem);
	font-weight: 900;
	letter-spacing: -0.04em;
	line-height: 0.95;
	margin: 4px 0 10px;
}

.about-stat span:not(.material-icons) {
	color: var(--ink);
	display: block;
	font-size: clamp(0.96rem, 1.05vw, 1.08rem);
	font-weight: 900;
	line-height: 1.25;
	max-width: 100%;
	white-space: normal;
}

.about-stat p {
	color: #314654;
	font-size: 0.86rem;
	font-weight: 600;
	line-height: 1.65;
	margin: 22px 0 0;
	max-width: 205px;
}

.about-values-section {
	padding: 0 0 30px;
}

.about-section-header {
	margin: 0 auto 18px;
	text-align: center;
}

.about-section-header > span {
	align-items: center;
	color: var(--teal);
	display: inline-flex;
	font-size: 0.98rem;
	font-weight: 900;
	gap: 7px;
	margin-bottom: 6px;
}

.about-section-header .material-icons {
	color: #4c9461;
	font-size: 20px;
}

.about-section-header h2 {
	font-size: clamp(1.7rem, 2.8vw, 2.25rem);
	font-weight: 900;
	letter-spacing: -0.045em;
	line-height: 1.14;
	margin: 0;
}

.about-values-grid {
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	margin-inline: auto;
	max-width: 1320px;
}

.about-value-card {
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(131, 170, 142, 0.12);
	border-radius: 10px;
	box-shadow: 0 16px 42px rgba(23, 58, 63, 0.08);
	min-height: 178px;
	padding: 28px 22px 24px;
	text-align: center;
}

.about-value-icon {
	align-items: center;
	background: rgba(53, 137, 145, 0.18);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	height: 58px;
	justify-content: center;
	width: 58px;
}

.about-value-icon .material-icons {
	font-size: 34px;
}

.about-value-icon-sage {
	background: rgba(131, 170, 142, 0.24);
	color: #4c8757;
}

.about-value-icon-olive {
	background: rgba(200, 213, 159, 0.34);
	color: #6a853b;
}

.about-value-card h3 {
	font-size: 1rem;
	font-weight: 900;
	line-height: 1.2;
	margin: 16px 0 8px;
}

.about-value-card p {
	color: #314654;
	font-size: 0.86rem;
	line-height: 1.65;
	margin: 0 auto;
	max-width: 210px;
}

.about-creator-section {
	padding: 0 0 26px;
}

.about-creator-grid {
	align-items: center;
	display: grid;
	gap: clamp(44px, 6vw, 92px);
	grid-template-columns: minmax(420px, 0.9fr) minmax(0, 1.1fr);
	margin: 0 auto;
	max-width: 1320px;
}

.about-creator-image img {
	border-radius: 12px;
	box-shadow: 0 18px 34px rgba(23, 58, 63, 0.08);
	height: 250px;
	object-fit: cover;
	width: 100%;
}

.about-creator-copy h3 {
	font-size: clamp(1.55rem, 2.8vw, 2rem);
	font-weight: 900;
	letter-spacing: -0.04em;
	line-height: 1.15;
	margin: 0 0 12px;
}

.about-creator-copy p {
	color: #314654;
	font-size: 0.92rem;
	line-height: 1.7;
	margin: 0 0 10px;
	max-width: 620px;
}

.category-hero-section {
	padding: 0 0 42px;
}

.category-hero {
	align-items: stretch;
	background:
		linear-gradient(135deg, rgba(230, 239, 237, 0.94), rgba(248, 246, 241, 0.9)),
		#eef3ec;
	border-radius: 34px;
	display: grid;
	gap: 28px;
	grid-template-columns: minmax(0, 0.9fr) minmax(360px, 1.1fr);
	min-height: 410px;
	overflow: hidden;
	position: relative;
}

.category-hero-copy {
	align-self: center;
	max-width: 570px;
	padding: clamp(42px, 6vw, 76px);
	position: relative;
	z-index: 2;
}

.category-hero-copy h1 {
	font-size: clamp(2.7rem, 5vw, 4.45rem);
	font-weight: 900;
	letter-spacing: -0.055em;
	line-height: 1.04;
	margin: 0;
}

.category-hero-copy p {
	color: #415360;
	font-size: clamp(1rem, 1.45vw, 1.22rem);
	margin: 22px 0 0;
	max-width: 470px;
}

.category-search-form {
	align-items: center;
	background: #fff;
	border: 1px solid rgba(131, 170, 142, 0.13);
	border-radius: 10px;
	box-shadow: 0 18px 44px rgba(23, 58, 63, 0.08);
	display: flex;
	gap: 12px;
	margin-top: 34px;
	max-width: 390px;
	padding: 0 18px;
}

.category-search-form input {
	background: transparent;
	border: 0;
	color: var(--ink);
	font: inherit;
	outline: 0;
	padding: 18px 0;
	width: 100%;
}

.category-hero-art {
	min-height: 410px;
	position: relative;
}

.category-hero-shape {
	background: var(--olive);
	border-radius: 46% 0 0 46%;
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	width: 54%;
}

.category-hero-art img {
	bottom: 44px;
	height: min(340px, 82%);
	object-fit: contain;
	position: absolute;
	right: clamp(190px, 24vw, 360px);
	width: min(360px, 43vw);
	z-index: 2;
}

.category-hero-book {
	background:
		linear-gradient(180deg, #f7f6ef 0 38%, #dedccf 39% 42%, #f7f6ef 43% 100%);
	border-radius: 4px;
	bottom: 48px;
	box-shadow: 0 18px 28px rgba(23, 58, 63, 0.12);
	height: 72px;
	position: absolute;
	right: clamp(64px, 8vw, 150px);
	width: min(390px, 44vw);
	z-index: 1;
}

.category-hero-book::before {
	background: #d8dac7;
	border-radius: 3px;
	content: "";
	height: 18px;
	left: 0;
	position: absolute;
	right: 0;
	top: -18px;
}

.category-hero-mug {
	background: #b9cab8;
	border-radius: 9px 16px 16px 9px;
	bottom: 144px;
	box-shadow: inset -14px 0 0 rgba(69, 100, 84, 0.12), 0 14px 24px rgba(23, 58, 63, 0.12);
	height: 96px;
	position: absolute;
	right: clamp(82px, 10vw, 182px);
	width: 88px;
	z-index: 3;
}

.category-hero-mug::after {
	border: 9px solid #89a28c;
	border-left: 0;
	border-radius: 0 999px 999px 0;
	content: "";
	height: 48px;
	position: absolute;
	right: -34px;
	top: 22px;
	width: 34px;
}

.category-list-section {
	padding: 0 0 34px;
}

.category-list-header {
	align-items: center;
	display: flex;
	justify-content: space-between;
	margin-bottom: 34px;
	padding-inline: 18px;
}

.category-list-header h2 {
	color: var(--teal);
	font-size: 1.28rem;
	font-weight: 900;
	margin: 0;
}

.category-sort-form {
	align-items: center;
	color: var(--ink);
	display: inline-flex;
	font-weight: 700;
	gap: 6px;
}

.category-sort-form select {
	appearance: none;
	background:
		linear-gradient(45deg, transparent 50%, var(--ink) 50%) calc(100% - 12px) 53% / 6px 6px no-repeat,
		linear-gradient(135deg, var(--ink) 50%, transparent 50%) calc(100% - 7px) 53% / 6px 6px no-repeat;
	border: 0;
	color: var(--ink);
	font: inherit;
	font-weight: 900;
	padding: 4px 24px 4px 2px;
}

.category-page-grid {
	display: grid;
	gap: 24px 32px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.category-page-card {
	background:
		radial-gradient(circle at 23% 22%, rgba(255, 255, 255, 0.78), transparent 120px),
		linear-gradient(135deg, rgba(225, 241, 244, 0.9), rgba(233, 238, 246, 0.82));
	border: 1px solid rgba(131, 170, 142, 0.1);
	border-radius: 12px;
	display: flex;
	flex-direction: column;
	min-height: 374px;
	padding: clamp(34px, 3.1vw, 46px);
}

.category-page-card[hidden],
.category-search-empty[hidden] {
	display: none;
}

.category-page-card:nth-child(3n + 2) {
	background:
		radial-gradient(circle at 23% 22%, rgba(255, 255, 255, 0.78), transparent 120px),
		linear-gradient(135deg, rgba(237, 241, 232, 0.9), rgba(232, 233, 229, 0.82));
}

.category-page-card:nth-child(3n) {
	background:
		radial-gradient(circle at 23% 22%, rgba(255, 255, 255, 0.78), transparent 120px),
		linear-gradient(135deg, rgba(246, 241, 228, 0.94), rgba(238, 234, 229, 0.84));
}

.category-page-card:nth-child(4) {
	background:
		radial-gradient(circle at 23% 22%, rgba(255, 255, 255, 0.78), transparent 120px),
		linear-gradient(135deg, rgba(246, 239, 229, 0.92), rgba(238, 234, 224, 0.84));
}

.category-page-card:nth-child(5) {
	background:
		radial-gradient(circle at 23% 22%, rgba(255, 255, 255, 0.78), transparent 120px),
		linear-gradient(135deg, rgba(230, 240, 244, 0.92), rgba(235, 237, 246, 0.84));
}

.category-page-card:nth-child(6) {
	background:
		radial-gradient(circle at 23% 22%, rgba(255, 255, 255, 0.78), transparent 120px),
		linear-gradient(135deg, rgba(235, 240, 235, 0.92), rgba(231, 232, 229, 0.84));
}

.category-page-icon {
	align-items: center;
	background: rgba(255, 255, 255, 0.64);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	height: 94px;
	justify-content: center;
	width: 94px;
}

.category-page-card:nth-child(3n + 2) .category-page-icon {
	color: #4b8c63;
}

.category-page-card:nth-child(3n) .category-page-icon {
	color: #628444;
}

.category-page-icon .material-icons {
	font-size: 50px;
}

.category-page-card h3 {
	font-size: 1.55rem;
	font-weight: 900;
	letter-spacing: -0.045em;
	line-height: 1.15;
	margin: 24px 0 8px;
}

.category-page-card p {
	color: #314654;
	font-size: 1.04rem;
	line-height: 1.55;
	margin: 0 0 18px;
	max-width: 340px;
}

.category-count {
	align-self: flex-start;
	background: rgba(131, 170, 142, 0.2);
	border-radius: 999px;
	color: #274b38;
	font-size: 0.82rem;
	font-weight: 900;
	margin-top: auto;
	padding: 5px 13px;
}

.category-page-card a {
	align-items: center;
	color: var(--teal);
	display: inline-flex;
	font-size: 1.02rem;
	font-weight: 900;
	gap: 8px;
	margin-top: 20px;
}

.category-page-card a .material-icons {
	font-size: 20px;
}

.contact-hero-section {
	padding: 48px 0 34px;
}

.contact-hero-grid {
	align-items: center;
	display: grid;
	gap: clamp(54px, 7vw, 112px);
	grid-template-columns: minmax(0, 0.84fr) minmax(420px, 1.16fr);
}

.contact-hero-copy {
	max-width: 520px;
}

.contact-hero-copy h1 {
	font-size: clamp(3rem, 5.1vw, 4.7rem);
	font-weight: 900;
	letter-spacing: -0.055em;
	line-height: 1.12;
	margin: 0;
}

.contact-hero-copy > p {
	color: #354b5a;
	font-size: 1rem;
	line-height: 1.75;
	margin: 22px 0 0;
	max-width: 450px;
}

.contact-note {
	align-items: center;
	background: linear-gradient(135deg, rgba(226, 239, 211, 0.88), rgba(244, 244, 232, 0.86));
	border-radius: 12px;
	display: flex;
	gap: 18px;
	margin-top: 28px;
	padding: 18px;
}

.contact-note-icon,
.contact-info-icon {
	align-items: center;
	background: rgba(53, 137, 145, 0.18);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	flex: 0 0 auto;
	height: 62px;
	justify-content: center;
	width: 62px;
}

.contact-note-icon {
	background: var(--teal);
	color: #fff;
	height: 52px;
	width: 52px;
}

.contact-note span:last-child {
	color: var(--ink);
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1.55;
}

.contact-hero-image {
	border-radius: 50px 36px 36px 50px;
	isolation: isolate;
	min-height: 430px;
	position: relative;
}

.contact-hero-image::before {
	background: var(--olive);
	border-radius: 80px;
	bottom: -14px;
	content: "";
	left: -36px;
	position: absolute;
	top: 86px;
	width: 162px;
	z-index: -1;
}

.contact-hero-image img {
	border-radius: 42px;
	height: 430px;
	object-fit: cover;
	width: 100%;
}

.contact-info-section {
	padding: 14px 0 30px;
}

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

.contact-info-card,
.contact-form-panel,
.contact-faq-panel {
	background: rgba(255, 255, 255, 0.78);
	border: 1px solid rgba(131, 170, 142, 0.14);
	border-radius: 16px;
	box-shadow: 0 18px 48px rgba(23, 58, 63, 0.08);
}

.contact-info-card {
	min-height: 230px;
	padding: 28px 28px 30px;
}

.contact-info-icon-sage {
	background: rgba(200, 213, 159, 0.3);
	color: #5d8649;
}

.contact-info-card h2 {
	font-size: 1.28rem;
	font-weight: 900;
	letter-spacing: -0.035em;
	line-height: 1.2;
	margin: 22px 0 4px;
}

.contact-info-card p {
	color: #314654;
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

.contact-info-card a {
	align-items: center;
	color: var(--teal);
	display: inline-flex;
	font-size: 0.95rem;
	font-weight: 900;
	gap: 8px;
	margin-top: 18px;
}

.contact-main-section {
	padding: 0 0 32px;
}

.contact-main-grid {
	align-items: stretch;
	display: grid;
	gap: 34px;
	grid-template-columns: minmax(0, 1.35fr) minmax(360px, 1fr);
}

.contact-form-panel,
.contact-faq-panel {
	padding: clamp(28px, 3vw, 38px);
}

.contact-form-panel h2,
.contact-faq-panel h2 {
	font-size: 1.42rem;
	font-weight: 900;
	letter-spacing: -0.035em;
	line-height: 1.2;
	margin: 0 0 24px;
}

.contact-popup {
	align-items: center;
	background: rgba(20, 38, 49, 0.42);
	display: flex;
	inset: 0;
	justify-content: center;
	padding: 22px;
	position: fixed;
	z-index: 120;
}

.contact-popup-card {
	background: #fff;
	border: 1px solid rgba(131, 170, 142, 0.2);
	border-radius: 14px;
	box-shadow: 0 24px 70px rgba(23, 58, 63, 0.22);
	max-width: 420px;
	padding: 30px;
	text-align: center;
	width: 100%;
}

.contact-popup-icon {
	align-items: center;
	background: rgba(53, 137, 145, 0.14);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	height: 60px;
	justify-content: center;
	margin-bottom: 14px;
	width: 60px;
}

.contact-popup-icon .material-icons {
	font-size: 34px;
}

.contact-popup-card h3 {
	font-size: 1.35rem;
	font-weight: 900;
	letter-spacing: -0.035em;
	margin: 0 0 8px;
}

.contact-popup-card p {
	color: #40515e;
	font-size: 0.95rem;
	line-height: 1.65;
	margin: 0;
}

.contact-popup-close {
	background: var(--teal);
	border-radius: 9px;
	color: #fff;
	display: inline-flex;
	font-weight: 900;
	justify-content: center;
	margin-top: 22px;
	min-width: 92px;
	padding: 11px 18px;
}

.contact-popup-close:hover,
.contact-popup-close:focus {
	background: var(--ink);
	color: #fff;
}

.contact-form-alert {
	background: rgba(200, 213, 159, 0.28);
	border: 1px solid rgba(131, 170, 142, 0.32);
	border-radius: 8px;
	color: var(--ink);
	font-size: 0.92rem;
	font-weight: 800;
	margin-bottom: 16px;
	padding: 12px 14px;
}

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

.contact-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.contact-form input,
.contact-form textarea {
	background: #fff;
	border: 1px solid rgba(102, 115, 125, 0.2);
	border-radius: 6px;
	color: var(--ink);
	font: inherit;
	outline: 0;
	padding: 14px 16px;
	width: 100%;
}

.contact-form input:focus,
.contact-form textarea:focus {
	border-color: var(--teal);
	box-shadow: 0 0 0 3px rgba(53, 137, 145, 0.12);
}

.contact-form input.has-error,
.contact-form input.has-error:focus,
.contact-form textarea.has-error,
.contact-form textarea.has-error:focus {
	border-color: #b94c4c;
	box-shadow: 0 0 0 3px rgba(185, 76, 76, 0.12);
}

.contact-field-full {
	grid-column: 1 / -1;
}

.contact-field-error {
	color: #9b3434;
	font-size: 0.84rem;
	font-weight: 700;
	line-height: 1.35;
	margin: 0;
}

.contact-field-error:empty {
	display: none;
}

.contact-form textarea {
	min-height: 136px;
	resize: vertical;
}

.contact-form button {
	align-items: center;
	background: var(--teal);
	border: 0;
	border-radius: 9px;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font: inherit;
	font-weight: 900;
	gap: 10px;
	justify-content: center;
	justify-self: start;
	padding: 14px 24px;
}

.contact-form button:hover,
.contact-form button:focus {
	background: var(--ink);
}

.contact-form button:disabled {
	background: #8fb6bb;
	cursor: not-allowed;
	opacity: 0.58;
}

.contact-form button:disabled:hover,
.contact-form button:disabled:focus {
	background: #8fb6bb;
}

.contact-privacy {
	align-items: center;
	color: var(--muted);
	display: flex;
	font-size: 0.82rem;
	gap: 8px;
	margin: 22px 0 0;
}

.contact-privacy .material-icons {
	font-size: 18px;
}

.contact-faq-panel {
	background: linear-gradient(135deg, rgba(248, 247, 239, 0.92), rgba(236, 240, 226, 0.86));
}

.contact-faq-list {
	display: grid;
	gap: 6px;
}

.contact-faq-item {
	background: rgba(255, 255, 255, 0.84);
	border-radius: 7px;
	overflow: hidden;
}

.contact-faq-item summary {
	cursor: pointer;
	font-size: 0.95rem;
	font-weight: 900;
	list-style: none;
	padding: 13px 18px;
	position: relative;
}

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

.contact-faq-item summary::after {
	content: "+";
	font-size: 1.25rem;
	font-weight: 500;
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY(-50%);
}

.contact-faq-item[open] summary::after {
	content: "-";
}

.contact-faq-item p {
	color: #40515e;
	font-size: 0.92rem;
	line-height: 1.65;
	margin: 0;
	padding: 0 18px 16px;
}

.contact-faq-footer {
	margin-top: 28px;
}

.contact-faq-footer p {
	font-size: 0.95rem;
	margin: 0 0 8px;
}

.contact-faq-footer a {
	align-items: center;
	color: var(--teal);
	display: inline-flex;
	font-weight: 900;
	gap: 8px;
}

.newsletter-card {
	align-items: center;
	background: linear-gradient(135deg, rgba(53, 137, 145, 0.94), rgba(131, 170, 142, 0.9));
	border-radius: 18px;
	color: #fff;
	display: grid;
	gap: 26px;
	grid-template-columns: 150px 1fr minmax(420px, 0.95fr);
	padding: clamp(28px, 5vw, 44px);
}

.newsletter-popup {
	align-items: center;
	background: rgba(20, 38, 49, 0.42);
	display: flex;
	inset: 0;
	justify-content: center;
	padding: 22px;
	position: fixed;
	z-index: 40;
}

.newsletter-popup-card {
	background: #fff;
	border: 1px solid rgba(131, 170, 142, 0.2);
	border-radius: 14px;
	box-shadow: var(--shadow-strong);
	color: var(--ink);
	max-width: 390px;
	padding: 30px;
	text-align: center;
	width: 100%;
}

.newsletter-popup-icon {
	align-items: center;
	background: rgba(53, 137, 145, 0.14);
	border-radius: 999px;
	color: var(--teal);
	display: inline-flex;
	height: 58px;
	justify-content: center;
	margin-bottom: 14px;
	width: 58px;
}

.newsletter-popup-icon .material-icons {
	font-size: 34px;
}

.newsletter-popup-card h3 {
	font-size: 1.35rem;
	font-weight: 900;
	letter-spacing: -0.035em;
	margin: 0 0 8px;
}

.newsletter-popup-card p {
	color: #40515e;
	font-size: 0.95rem;
	line-height: 1.65;
	margin: 0 0 20px;
}

.newsletter-popup-close {
	background: var(--teal);
	border-radius: 9px;
	color: #fff;
	display: inline-flex;
	font-weight: 900;
	padding: 12px 24px;
}

.newsletter-popup-close:hover,
.newsletter-popup-close:focus {
	background: var(--ink);
	color: #fff;
}

.newsletter-form-alert {
	background: rgba(255, 250, 247, 0.95);
	border: 1px solid rgba(255, 255, 255, 0.46);
	border-radius: 8px;
	color: #9b3434;
	font-size: 0.9rem;
	font-weight: 800;
	grid-column: 1 / -1;
	padding: 10px 12px;
}

.newsletter-icon {
	align-items: center;
	color: var(--teal);
	display: inline-flex;
	height: 165px;
	justify-content: center;
	overflow: hidden;
	width: 165px;
}

.newsletter-icon img {
	height: 100%;
	object-fit: contain;
	object-position: center;
	width: 100%;
}

.newsletter-card h2 {
	font-size: clamp(2rem, 4vw, 3rem);
	letter-spacing: -0.05em;
	line-height: 1;
	margin: 0 0 10px;
}

.newsletter-card p {
	margin: 0;
	max-width: 420px;
}

.newsletter-form {
	display: grid;
	gap: 10px;
	grid-template-columns: 1fr auto;
}

.newsletter-form input {
	border: 0;
	border-radius: 10px;
	font: inherit;
	padding: 16px 18px;
}

.newsletter-form input.has-error {
	box-shadow: 0 0 0 3px rgba(185, 76, 76, 0.22);
}

.newsletter-form button {
	background: var(--cream);
	border: 0;
	border-radius: 10px;
	color: var(--teal);
	cursor: pointer;
	font-weight: 900;
	padding: 16px 24px;
}

.newsletter-form button:disabled {
	cursor: not-allowed;
	opacity: 0.58;
}

.newsletter-field-error {
	color: #fff;
	font-size: 0.82rem;
	font-weight: 800;
	grid-column: 1 / -1;
	line-height: 1.35;
	margin: 0;
}

.newsletter-field-error:empty {
	display: none;
}

.newsletter-form span {
	font-size: 0.82rem;
	grid-column: 1 / -1;
	opacity: 0.9;
}

.empty-state {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 14px;
	box-shadow: var(--shadow);
	padding: 30px;
}

.pagination {
	margin-top: 34px;
}

.nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.page-numbers {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 999px;
	font-weight: 800;
	padding: 8px 13px;
}

.page-numbers.current {
	background: var(--teal);
	color: #fff;
}

.post-preview-page {
	background:
		radial-gradient(circle at 42% 2%, rgba(214, 225, 186, 0.24), transparent 24rem),
		linear-gradient(180deg, #fffbfa 0%, #fbfaf7 100%);
	font-size: 13px;
	line-height: 1.65;
	padding: 34px 0 86px;
}

.post-preview-shell {
	max-width: 1460px;
	padding-inline: clamp(42px, 5vw, 88px);
}

.post-back-link {
	align-items: center;
	color: #0d8588;
	display: inline-flex;
	font-size: 12px;
	font-weight: 900;
	gap: 6px;
	margin-bottom: 20px;
}

.post-back-link .material-icons {
	font-size: 17px;
}

.post-preview-layout {
	align-items: start;
	display: grid;
	gap: clamp(48px, 5vw, 78px);
	grid-template-columns: minmax(0, 860px) 360px;
	justify-content: center;
}

.post-preview-article {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 360px;
	column-gap: 46px;
	min-width: 0;
	overflow-wrap: anywhere;
}

.post-preview-article-no-image {
	grid-template-columns: minmax(0, 1fr);
}

.post-preview-article-no-image .post-preview-header,
.post-preview-article-no-image .post-preview-content,
.post-preview-article-no-image .post-preview-share-row {
	max-width: 720px;
}

.post-preview-article-no-image .post-preview-content,
.post-preview-article-no-image .post-preview-share-row {
	margin-left: 0;
	margin-right: 0;
}

.post-preview-header {
	min-width: 0;
	padding-right: 0;
}

.post-preview-header,
.post-preview-hero-image,
.post-preview-sidebar,
.post-preview-side-card,
.post-preview-popular-item span {
	min-width: 0;
}

.post-preview-kicker {
	align-items: center;
	display: flex;
	gap: 10px;
	margin-bottom: 14px;
}

.post-preview-kicker span {
	background: #edf0f2;
	border-radius: 999px;
	color: #22343d;
	font-size: 10px;
	font-weight: 900;
	padding: 3px 11px;
}

.post-preview-kicker span:first-child {
	background: rgba(131, 170, 142, 0.26);
	color: #4d7d5a;
}

.post-preview-header h1 {
	color: #142631;
	font-size: clamp(34px, 2.7vw, 46px);
	font-weight: 900;
	letter-spacing: -0.045em;
	line-height: 1.18;
	margin: 0;
	max-width: 510px;
	overflow-wrap: anywhere;
}

.post-preview-dek {
	color: #334a58;
	font-size: 17px;
	line-height: 1.62;
	margin: 22px 0 0;
	max-width: 500px;
	overflow-wrap: anywhere;
}

.post-preview-author {
	align-items: center;
	display: flex;
	gap: 12px;
	margin-top: 22px;
}

.post-preview-author img {
	border-radius: 999px;
	height: 43px;
	object-fit: cover;
	width: 43px;
}

.post-preview-author strong {
	display: block;
	font-size: 11px;
	font-weight: 900;
	line-height: 1.2;
}

.post-preview-author span {
	color: #52636d;
	display: block;
	font-size: 10px;
	margin-top: 5px;
}

.post-preview-hero-image {
	grid-column: 2;
	grid-row: 1 / span 2;
	margin: -6px 0 0;
}

.post-preview-hero-image img {
	border-radius: 32px;
	height: 455px;
	object-fit: cover;
	width: 360px;
}

.post-preview-content {
	color: #334a58;
	font-size: 15px;
	grid-column: 1 / -1;
	line-height: 1.62;
	margin: 42px auto 0;
	max-width: 720px;
	overflow-wrap: anywhere;
	width: 100%;
}

.post-preview-content p {
	margin: 0 0 13px;
	overflow-wrap: anywhere;
}

.post-preview-content h2 {
	color: #142631;
	font-size: 20px;
	font-weight: 900;
	letter-spacing: -0.02em;
	line-height: 1.25;
	margin: 18px 0 7px;
}

.post-preview-content blockquote {
	align-items: center;
	background: linear-gradient(90deg, rgba(219, 234, 206, 0.82), rgba(241, 238, 222, 0.82));
	border: 0;
	border-radius: 7px;
	display: grid;
	margin: 15px 0 18px;
	min-height: 78px;
	padding: 18px 28px 18px 86px;
	position: relative;
}

.post-preview-content blockquote::before {
	color: #5d9a74;
	content: "\201C";
	font-family: Georgia, serif;
	font-size: 62px;
	font-weight: 900;
	left: 28px;
	line-height: 1;
	position: absolute;
	top: 6px;
}

.post-preview-content blockquote p {
	color: #40505a;
	font-size: 15px;
	line-height: 1.45;
	margin: 0;
	overflow-wrap: anywhere;
}

.post-preview-share-row {
	border-top: 1px solid rgba(20, 38, 49, 0.12);
	display: flex;
	gap: 28px;
	grid-column: 1 / -1;
	justify-content: space-between;
	margin: 26px auto 0;
	max-width: 720px;
	padding-top: 22px;
}

.post-preview-share,
.post-preview-tags {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 11px;
}

.post-preview-share > span,
.post-preview-tags > span {
	color: #142631;
	font-size: 12px;
	font-weight: 900;
}

.post-preview-share a {
	align-items: center;
	background: rgba(131, 170, 142, 0.24);
	border-radius: 999px;
	color: #2f8c74;
	display: inline-flex;
	font-size: 14px;
	font-weight: 900;
	height: 32px;
	justify-content: center;
	width: 32px;
}

.post-preview-share a .material-icons {
	font-size: 17px;
}

.post-preview-share a svg,
.post-preview-author-socials a svg {
	fill: currentColor;
	height: 16px;
	width: 16px;
}

.post-preview-tags a {
	background: rgba(131, 170, 142, 0.24);
	border-radius: 999px;
	color: #4d7d5a;
	font-size: 11px;
	font-weight: 800;
	padding: 7px 12px;
}

.post-preview-author-card {
	align-items: center;
	background: linear-gradient(135deg, rgba(230, 240, 233, 0.88), rgba(247, 249, 247, 0.92));
	border-radius: 14px;
	display: grid;
	gap: 30px;
	grid-column: 1 / -1;
	grid-template-columns: 104px minmax(0, 1fr);
	margin: 28px 0 0;
	padding: 38px 46px;
	overflow-wrap: anywhere;
}

.post-preview-author-card > img {
	border-radius: 999px;
	height: 86px;
	object-fit: cover;
	width: 86px;
}

.post-preview-author-card span {
	color: #3d756d;
	font-size: 13px;
}

.post-preview-author-card h2 {
	font-size: 18px;
	font-weight: 900;
	line-height: 1.2;
	margin: 6px 0 9px;
}

.post-preview-author-card p {
	color: #40505a;
	font-size: 13px;
	line-height: 1.65;
	margin: 0;
	max-width: 640px;
}

.post-preview-author-socials {
	display: flex;
	gap: 14px;
	margin-top: 14px;
}

.post-preview-author-socials a {
	align-items: center;
	background: rgba(131, 170, 142, 0.22);
	border-radius: 999px;
	color: #2f8c74;
	display: inline-flex;
	font-size: 13px;
	font-weight: 900;
	height: 28px;
	justify-content: center;
	width: 28px;
}

.post-preview-author-socials a svg {
	height: 14px;
	width: 14px;
}

.post-preview-related {
	grid-column: 1 / -1;
	margin-top: 30px;
}

.post-preview-related > h2 {
	font-size: 19px;
	font-weight: 900;
	line-height: 1.25;
	margin: 0 0 18px;
}

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

.post-preview-related-card {
	background: rgba(255, 255, 255, 0.88);
	border: 1px solid rgba(131, 170, 142, 0.12);
	border-radius: 12px;
	box-shadow: 0 16px 34px rgba(23, 58, 63, 0.09);
	color: #142631;
	overflow: hidden;
	padding-bottom: 18px;
}

.post-preview-related-card img {
	aspect-ratio: 181 / 88;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.post-preview-related-card > span {
	background: rgba(131, 170, 142, 0.24);
	border-radius: 999px;
	color: #4d7d5a;
	display: inline-flex;
	font-size: 10px;
	font-weight: 900;
	margin: 14px 16px 0;
	padding: 5px 10px;
}

.post-preview-related-card strong {
	display: block;
	font-size: 15px;
	font-weight: 900;
	letter-spacing: -0.02em;
	line-height: 1.3;
	margin: 12px 16px 10px;
	overflow-wrap: anywhere;
}

.post-preview-related-card small {
	align-items: center;
	color: #52636d;
	display: flex;
	font-size: 11px;
	font-weight: 700;
	gap: 7px;
	margin: 0 16px;
}

.post-preview-related-card small .material-icons {
	font-size: 13px;
}

.post-preview-sidebar {
	display: grid;
	gap: 18px;
	min-width: 0;
	overflow-wrap: anywhere;
}

.post-preview-about-box,
.post-preview-side-card,
.post-preview-subscribe {
	background: rgba(255, 255, 255, 0.82);
	border: 1px solid rgba(131, 170, 142, 0.12);
	border-radius: 14px;
	box-shadow: 0 15px 36px rgba(23, 58, 63, 0.07);
	overflow: hidden;
}

.post-preview-about-box {
	display: grid;
	column-gap: 22px;
	grid-template-columns: minmax(0, 1fr) 126px;
	min-height: 232px;
	padding: 28px 0 0 28px;
}

.post-preview-about-box > div {
	align-self: start;
	padding-bottom: 28px;
}

.post-preview-about-box h2,
.post-preview-side-card h2 {
	color: #0d8588;
	font-size: 16px;
	font-weight: 900;
	line-height: 1.2;
	margin: 0;
}

.post-preview-about-box p {
	color: #40505a;
	font-size: 14px;
	line-height: 1.7;
	margin: 18px 0 12px;
	max-width: none;
	overflow-wrap: anywhere;
}

.post-preview-about-box a,
.post-preview-side-link {
	color: #0d8588;
	font-size: 13px;
	font-weight: 900;
}

.post-preview-about-box img {
	align-self: stretch;
	height: 100%;
	min-height: 232px;
	object-fit: cover;
	object-position: center top;
	width: 126px;
}

.post-preview-side-card {
	padding: 28px 28px 24px;
}

.post-preview-category-list {
	display: grid;
	list-style: none;
	margin: 18px 0 16px;
	padding: 0;
}

.post-preview-category-list li {
	border-bottom: 1px solid rgba(20, 38, 49, 0.08);
}

.post-preview-category-list li:last-child {
	border-bottom: 0;
}

.post-preview-category-list a {
	align-items: center;
	color: #40505a;
	display: grid;
	font-size: 14px;
	font-weight: 700;
	gap: 13px;
	grid-template-columns: 27px 1fr auto;
	min-height: 48px;
	min-width: 0;
	overflow-wrap: anywhere;
}

.post-preview-category-list .material-icons {
	align-items: center;
	background: rgba(131, 170, 142, 0.16);
	border: 1px solid rgba(131, 170, 142, 0.26);
	border-radius: 999px;
	color: #5d9a74;
	display: inline-flex;
	font-size: 16px;
	height: 20px;
	justify-content: center;
	width: 20px;
}

.post-preview-category-list b {
	color: #6c7880;
	font-size: 10px;
	font-weight: 800;
}

.post-preview-popular-list {
	display: grid;
	gap: 16px;
	margin-top: 18px;
}

.post-preview-popular-item {
	display: grid;
	gap: 14px;
	grid-template-columns: 96px minmax(0, 1fr);
}

.post-preview-popular-item img {
	border-radius: 7px;
	height: 78px;
	object-fit: cover;
	width: 96px;
}

.post-preview-popular-item strong {
	color: #142631;
	display: block;
	font-size: 14px;
	font-weight: 900;
	letter-spacing: -0.02em;
	line-height: 1.24;
	overflow-wrap: anywhere;
}

.post-preview-popular-item small {
	color: #52636d;
	display: block;
	font-size: 12px;
	margin-top: 5px;
}

.post-preview-subscribe {
	background: linear-gradient(135deg, #63a68d 0%, #3d8c87 100%);
	border: 0;
	color: #fff;
	min-height: 360px;
	padding: 34px 34px 30px;
	position: relative;
}

.post-preview-subscribe > img {
	height: 112px;
	object-fit: contain;
	position: absolute;
	right: 30px;
	top: 38px;
	width: 112px;
}

.post-preview-subscribe h2 {
	color: #fff;
	font-size: 31px;
	font-weight: 900;
	letter-spacing: -0.035em;
	line-height: 1.1;
	margin: 0 132px 22px 0;
}

.post-preview-subscribe p {
	color: #fff;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.75;
	margin: 0 0 28px;
	max-width: 295px;
}

.post-preview-subscribe .newsletter-form {
	display: grid;
	gap: 14px;
	grid-template-columns: 1fr;
}

.post-preview-subscribe .newsletter-form input {
	background: #fff;
	border: 0;
	border-radius: 10px;
	color: var(--ink);
	font-size: 15px;
	min-height: 58px;
	min-width: 0;
	padding: 0 24px;
	width: 100%;
}

.post-preview-subscribe .newsletter-form button {
	background: #e8e0ac;
	border: 0;
	border-radius: 10px;
	color: #1d554e;
	font-size: 16px;
	font-weight: 900;
	grid-column: 1;
	min-height: 58px;
	width: 100%;
}

.post-preview-subscribe .newsletter-form span {
	color: #fff;
	font-size: 15px;
	margin-top: 8px;
}

.post-preview-subscribe .newsletter-field-error {
	color: #fff;
	font-size: 13px;
	margin: 0;
}

.archive-sustainability-page {
	background: #fffdfa;
	color: #111;
	font-family: var(--font-body);
	font-size: 16px;
	padding-bottom: 70px;
}

.archive-sustainability-page .container {
	max-width: 1440px;
	padding-inline: clamp(42px, 6vw, 96px);
}

.archive-category-hero {
	background:
		radial-gradient(circle at 22% 12%, rgba(131, 170, 142, 0.13), transparent 15rem),
		linear-gradient(180deg, #f8f8f4 0%, #f4f5ef 100%);
	border-bottom: 1px solid rgba(27, 47, 34, 0.05);
	padding: 58px 0 62px;
}

.archive-category-hero-inner {
	align-items: center;
	display: grid;
	gap: 42px;
	grid-template-columns: 150px minmax(0, 1fr);
	max-width: 980px;
}

.archive-category-mark {
	align-items: center;
	background: rgba(226, 231, 220, 0.76);
	border-radius: 999px;
	display: flex;
	height: 150px;
	justify-content: center;
	width: 150px;
}

.archive-category-mark svg {
	fill: none;
	height: 84px;
	stroke: #427b43;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: 3;
	width: 84px;
}

.archive-category-heading h1 {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 43px;
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.05;
	margin: 0 0 16px;
}

.archive-category-heading p {
	color: #42505a;
	font-size: 16px;
	line-height: 1.7;
	margin: 0 0 18px;
	max-width: 560px;
}

.archive-category-count {
	align-items: center;
	color: #2f6b38;
	display: inline-flex;
	font-size: 16px;
	font-weight: 900;
	gap: 8px;
}

.archive-category-count .material-icons {
	font-size: 20px;
}

.archive-category-content {
	padding-top: 34px;
}

.archive-category-layout {
	align-items: start;
	display: grid;
	gap: 52px;
	grid-template-columns: minmax(0, 1fr) 300px;
}

.archive-category-toolbar {
	align-items: center;
	display: flex;
	gap: 24px;
	justify-content: space-between;
	margin-bottom: 28px;
}

.archive-category-search {
	align-items: center;
	background: #fff;
	border: 1px solid #dfe4df;
	border-radius: 7px;
	display: flex;
	gap: 12px;
	height: 46px;
	max-width: 430px;
	padding: 0 17px;
	width: 100%;
}

.archive-category-search .material-icons {
	color: #33424a;
	font-size: 22px;
}

.archive-category-search input {
	background: transparent;
	border: 0;
	color: #33424a;
	font: inherit;
	font-size: 14px;
	outline: 0;
	width: 100%;
}

.archive-category-search input::placeholder {
	color: #68747b;
}

.archive-category-sort {
	align-items: center;
	color: #111;
	display: inline-flex;
	font-size: 14px;
	font-weight: 900;
	gap: 12px;
	white-space: nowrap;
}

.archive-category-sort select {
	appearance: none;
	background:
		linear-gradient(45deg, transparent 50%, #29353b 50%) calc(100% - 13px) 50% / 6px 6px no-repeat,
		linear-gradient(135deg, #29353b 50%, transparent 50%) calc(100% - 8px) 50% / 6px 6px no-repeat,
		#fff;
	border: 1px solid #dfe4df;
	border-radius: 7px;
	color: #111;
	font: inherit;
	font-weight: 800;
	height: 46px;
	min-width: 150px;
	padding: 0 42px 0 16px;
}

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

.archive-post-card {
	background: #fff;
	border: 1px solid #e3e7e1;
	border-radius: 8px;
	box-shadow: 0 9px 24px rgba(23, 58, 63, 0.04);
	display: flex;
	flex-direction: column;
	min-width: 0;
	overflow: hidden;
}

.archive-post-image {
	background: #eef1e9;
	display: block;
	height: 174px;
	overflow: hidden;
}

.archive-post-image img {
	height: 100%;
	object-fit: cover;
	object-position: center;
	width: 100%;
}

.archive-post-card-body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 18px 20px 20px;
}

.archive-post-card time {
	color: #267037;
	font-size: 13px;
	font-weight: 900;
	margin-bottom: 10px;
}

.archive-post-card h2 {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 23px;
	font-weight: 700;
	letter-spacing: -0.015em;
	line-height: 1.12;
	margin: 0 0 12px;
}

.archive-post-card p {
	color: #3b4650;
	font-size: 15px;
	line-height: 1.55;
	margin: 0 0 14px;
}

.archive-post-read-more {
	color: #2f7f3b;
	font-size: 14px;
	font-weight: 900;
	margin-top: auto;
}

.archive-category-sidebar {
	display: grid;
	gap: 17px;
}

.archive-category-about,
.archive-category-panel,
.archive-category-subscribe {
	background: #fff;
	border: 1px solid #e2e7df;
	border-radius: 8px;
	box-shadow: 0 10px 24px rgba(23, 58, 63, 0.04);
	padding: 24px 24px;
}

.archive-category-about,
.archive-category-subscribe {
	background: linear-gradient(135deg, #f3f6ef, #e9eee4);
	border-color: rgba(131, 170, 142, 0.12);
}

.archive-category-about h2,
.archive-category-panel h2,
.archive-category-subscribe h2 {
	font-family: Georgia, "Times New Roman", serif;
	font-size: 20px;
	line-height: 1.2;
	margin: 0 0 13px;
}

.archive-category-about p,
.archive-category-subscribe p {
	color: #303a40;
	font-size: 14px;
	line-height: 1.65;
	margin: 0 0 17px;
}

.archive-category-about a {
	border: 1px solid #5f8b5f;
	border-radius: 5px;
	color: #2e6633;
	display: inline-flex;
	font-size: 14px;
	font-weight: 900;
	padding: 8px 16px;
}

.archive-topic-list {
	display: grid;
	list-style: none;
	margin: 4px 0 0;
	padding: 0;
}

.archive-topic-list li {
	align-items: center;
	border-bottom: 1px solid #e5e9e2;
	color: #111;
	display: grid;
	font-size: 14px;
	font-weight: 800;
	gap: 12px;
	grid-template-columns: 24px minmax(0, 1fr);
	min-height: 36px;
}

.archive-topic-list li:last-child {
	border-bottom: 0;
}

.archive-topic-list .material-icons {
	align-items: center;
	background: rgba(131, 170, 142, 0.18);
	border: 1px solid rgba(131, 170, 142, 0.2);
	border-radius: 5px;
	color: #5e8b5d;
	display: inline-flex;
	font-size: 15px;
	height: 22px;
	justify-content: center;
	width: 22px;
}

.archive-subscribe-form {
	display: grid;
	gap: 8px;
}

.archive-subscribe-form input {
	background: #fff;
	border: 1px solid #dce2d9;
	border-radius: 5px;
	color: #111;
	font: inherit;
	font-size: 14px;
	height: 38px;
	padding: 0 12px;
	width: 100%;
}

.archive-subscribe-form button {
	background: linear-gradient(180deg, #4c8b4d, #376e38);
	border: 0;
	border-radius: 5px;
	color: #fff;
	font: inherit;
	font-size: 14px;
	font-weight: 900;
	height: 38px;
	justify-self: start;
	padding: 0 24px;
}

.archive-subscribe-form span {
	color: #5d676d;
	font-size: 12px;
}

.archive-category-pagination {
	align-items: center;
	display: flex;
	gap: 12px;
	justify-content: center;
	margin-top: 18px;
}

.archive-category-pagination .page-numbers {
	background: #fff;
	border: 1px solid #dce3dc;
	border-radius: 5px;
	color: #111;
	font-size: 14px;
	font-weight: 800;
	min-width: 40px;
	padding: 7px 12px;
	text-align: center;
}

.archive-category-pagination .page-numbers.current {
	background: linear-gradient(180deg, #4c8b4d, #376e38);
	border-color: #376e38;
	color: #fff;
}

.archive-category-pagination .page-numbers.dots {
	background: transparent;
	border-color: transparent;
	min-width: auto;
}

.archive-category-pagination .page-numbers.next {
	min-width: 92px;
}

.site-footer {
	background: linear-gradient(135deg, var(--cream) 0%, #f8f6f1 100%);
	color: var(--muted);
	padding: 64px 0 24px;
}

.footer-grid {
	align-items: start;
	display: grid;
	gap: clamp(44px, 6vw, 104px);
	grid-template-columns: minmax(260px, 1.2fr) minmax(130px, 0.65fr) minmax(150px, 0.75fr) minmax(170px, 0.8fr) minmax(330px, 1.35fr);
}

.footer-title {
	color: var(--teal);
	font-size: clamp(2rem, 3vw, 2.45rem);
	font-weight: 900;
	letter-spacing: -0.05em;
}

.footer-grid p {
	color: var(--ink);
	font-size: 1.03rem;
	font-weight: 600;
	line-height: 1.85;
	margin: 26px 0 0;
	max-width: 250px;
}

.footer-heading {
	color: var(--ink);
	font-size: 1.35rem;
	font-weight: 900;
	line-height: 1.25;
	margin: 0 0 24px;
}

.footer-links,
.footer-links ul,
.footer-grid .menu,
.social-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

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

.footer-links,
.footer-links ul,
.footer-grid .menu {
	display: grid;
	row-gap: 12px;
}

.footer-grid > div:not(:first-child) ul {
	display: grid;
	row-gap: 12px;
}

.site-footer .social-links {
	display: flex;
	flex-direction: row;
}

.footer-links a,
.footer-grid .menu a {
	color: var(--ink);
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.45;
}

.site-footer a:not(.footer-title):not(.social-links a) {
	color: var(--ink);
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.45;
}

.social-links {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-top: 38px;
}

.social-links a {
	align-items: center;
	background: var(--teal);
	border-radius: 999px;
	color: #fff;
	display: inline-flex;
	height: 42px;
	justify-content: center;
	width: 42px;
}

.social-links svg {
	fill: currentColor;
	height: 22px;
	width: 22px;
}

.footer-image {
	border-radius: 18px;
	overflow: hidden;
	box-shadow: 0 18px 30px rgba(23, 58, 63, 0.1);
	min-height: 210px;
}

.footer-image img {
	height: 100%;
	min-height: 210px;
	object-fit: cover;
	width: 100%;
}

.footer-bottom {
	border-top: 1px solid rgba(131, 170, 142, 0.28);
	display: flex;
	font-size: 0.9rem;
	font-weight: 700;
	justify-content: center;
	margin-top: 36px;
	padding-top: 24px;
}

@media (max-width: 980px) {
	body.admin-bar .site-header {
		top: 46px;
	}

	.header-inner {
		grid-template-columns: 1fr auto;
	}

	.primary-navigation {
		background: #fff;
		border: 1px solid var(--line);
		border-radius: 18px;
		display: none;
		grid-column: 1 / -1;
		justify-self: stretch;
		padding: 18px;
	}

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

	.primary-navigation ul {
		align-items: flex-start;
		flex-direction: column;
		gap: 14px;
	}

	.header-actions {
		display: none;
	}

	.hero-grid,
	.post-preview-layout,
	.post-preview-article,
	.archive-category-layout,
	.post-grid,
	.about-hero,
	.about-stats,
	.about-values-grid,
	.about-creator-grid,
	.category-hero,
	.category-page-grid,
	.contact-hero-grid,
	.contact-info-grid,
	.contact-main-grid,
	.newsletter-card,
	.footer-grid {
		grid-template-columns: 1fr;
	}

	.contact-hero-section {
		padding-top: 28px;
	}

	.contact-hero-grid {
		gap: 32px;
	}

	.contact-hero-copy {
		max-width: 680px;
	}

	.contact-hero-image {
		min-height: 360px;
	}

	.contact-hero-image img {
		height: 360px;
	}

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

	.contact-main-grid {
		gap: 24px;
	}

	.category-hero-art {
		min-height: 320px;
		order: -1;
	}

	.category-hero-copy {
		padding-top: 0;
	}

	.category-hero-art img {
		right: 42%;
		transform: translateX(50%);
		width: min(320px, 60vw);
	}

	.category-hero-book {
		right: 8%;
		width: min(360px, 62vw);
	}

	.category-hero-mug {
		right: 12%;
	}

	.category-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.hero-card {
		min-height: 330px;
	}

	.hero-card img {
		min-height: 330px;
	}

	.about-hero {
		padding: 34px;
	}

	.about-hero-image img {
		height: 330px;
	}

	.about-stats {
		gap: 24px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		padding-inline: 34px;
	}

	.about-stats-section .container {
		padding-inline: 34px;
	}

	.about-stat,
	.about-stat + .about-stat {
		border-left: 0;
		padding-left: 0;
		padding-inline: 0;
	}

	.about-stat:not(:last-child)::after {
		display: none;
	}

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

	.about-creator-grid {
		max-width: 760px;
	}

	.post-preview-page {
		padding-top: 24px;
	}

	.post-preview-shell {
		max-width: 760px;
		padding-inline: 28px;
	}

	.post-preview-layout {
		gap: 28px;
	}

	.post-preview-header,
	.post-preview-content,
	.post-preview-share-row,
	.post-preview-author-card,
	.post-preview-related > h2 {
		margin-left: 0;
		margin-right: 0;
		max-width: none;
		padding-right: 0;
	}

	.post-preview-hero-image {
		grid-column: auto;
		grid-row: auto;
		margin: 8px 0 0;
	}

	.post-preview-hero-image img {
		aspect-ratio: 16 / 10;
		height: auto;
		width: 100%;
	}

	.post-preview-content,
	.post-preview-share-row,
	.post-preview-author-card,
	.post-preview-related {
		grid-column: auto;
	}

	.post-preview-sidebar {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.archive-category-sidebar {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.post-preview-subscribe {
		grid-column: 1 / -1;
	}
}

@media (max-width: 640px) {
	body.admin-bar .site-header {
		top: 46px;
	}

	.site-main.about-page,
	.site-main.categories-page,
	.site-main.archive-sustainability-page {
		padding-top: 20px;
	}

	.container {
		padding-inline: 18px;
	}

	.hero-title {
		font-size: clamp(2.65rem, 15vw, 4rem);
	}

	.hero-actions,
	.newsletter-form,
	.category-list-header,
	.contact-form,
	.about-stats,
	.about-values-grid,
	.category-grid {
		grid-template-columns: 1fr;
	}

	.post-preview-shell {
		padding-inline: 18px;
	}

	.post-preview-header h1 {
		font-size: 29px;
	}

	.post-preview-share-row {
		gap: 12px;
		justify-content: flex-start;
	}

	.post-preview-author-card,
	.post-preview-related-grid,
	.post-preview-sidebar,
	.archive-category-hero-inner,
	.archive-post-grid,
	.archive-category-sidebar {
		grid-template-columns: 1fr;
	}

	.archive-sustainability-page .container {
		padding-inline: 18px;
	}

	.archive-category-hero {
		padding: 30px 0 34px;
	}

	.archive-category-hero-inner {
		justify-items: start;
	}

	.archive-category-mark {
		height: 96px;
		width: 96px;
	}

	.archive-category-toolbar {
		align-items: stretch;
		display: grid;
	}

	.archive-category-search {
		max-width: none;
	}

	.post-preview-author-card {
		align-items: start;
	}

	.post-preview-related-card img {
		aspect-ratio: 16 / 7;
	}

	.post-preview-about-box {
		column-gap: 14px;
		grid-template-columns: minmax(0, 1fr) 84px;
	}

	.post-preview-about-box img {
		width: 84px;
	}

	.contact-hero-section {
		padding-top: 20px;
	}

	.contact-hero-copy h1 {
		font-size: clamp(2.5rem, 12vw, 3.6rem);
	}

	.contact-note {
		align-items: flex-start;
	}

	.contact-hero-image {
		border-radius: 24px;
		min-height: 270px;
	}

	.contact-hero-image::before {
		border-radius: 42px;
		left: -16px;
		top: 54px;
		width: 82px;
	}

	.contact-hero-image img {
		border-radius: 24px;
		height: 270px;
	}

	.contact-info-grid {
		grid-template-columns: 1fr;
	}

	.contact-info-card {
		min-height: 0;
	}

	#contact-subject,
	.contact-form textarea {
		grid-column: auto;
	}

	.category-hero-section {
		padding-top: 12px;
	}

	.category-hero {
		border-radius: 22px;
	}

	.category-hero-copy {
		padding: 0 24px 30px;
	}

	.category-hero-copy h1 {
		font-size: clamp(2.55rem, 12vw, 3.45rem);
	}

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

	.category-hero-art {
		min-height: 260px;
	}

	.category-hero-art img {
		bottom: 34px;
		width: min(260px, 66vw);
	}

	.category-hero-book {
		bottom: 36px;
		height: 58px;
		right: 6%;
		width: 70%;
	}

	.category-hero-mug {
		bottom: 116px;
		height: 74px;
		right: 12%;
		width: 66px;
	}

	.category-hero-mug::after {
		height: 34px;
		right: -25px;
		top: 18px;
		width: 24px;
	}

	.category-list-header {
		align-items: flex-start;
		display: grid;
		gap: 8px;
		padding-inline: 0;
	}

	.category-page-card {
		min-height: 0;
	}

	.about-hero-section {
		padding-top: 12px;
	}

	.about-hero {
		border-radius: 22px;
		padding: 28px 22px;
	}

	.about-hero h1 {
		font-size: clamp(2.35rem, 11vw, 3.25rem);
	}

	.about-hero-image::after {
		border-radius: 28px;
		right: -12px;
		width: 82px;
	}

	.about-hero-image img {
		border-radius: 64px 20px 52px 20px;
		height: 260px;
	}

	.about-stats {
		padding: 24px;
	}

	.about-stats-section .container {
		padding-inline: 18px;
	}

	.about-stat {
		gap: 18px;
		grid-template-columns: 62px 1fr;
	}

	.about-stat-icon {
		height: 62px;
		width: 62px;
	}

	.about-stat-icon svg {
		height: 30px;
		width: 30px;
	}

	.about-stat p {
		margin-top: 12px;
		max-width: none;
	}

	.about-stat span:not(.material-icons) {
		white-space: normal;
	}

	.about-value-card {
		min-height: 0;
	}

	.about-creator-grid {
		gap: 24px;
	}

	.about-creator-image img {
		height: 230px;
	}

	.section-heading {
		align-items: flex-start;
		flex-direction: column;
		gap: 10px;
	}
}
