/*
Theme Name: COLDICP
Theme URI: https://coldicp.com
Author: COLDICP Team
Author URI: https://coldicp.com
Description: A fast, SEO-optimized WordPress block theme for COLDICP — the B2B cold outreach system. Features: light lime-wash brand palette, capsule floating navbar, Syne + DM Sans typography, 13-section homepage, 3-column blog layout, reading progress bar, TOC sidebar, schema markup, and full Core Web Vitals optimization.
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: coldicp
Tags: blog, custom-colors, custom-menu, custom-logo, editor-style, featured-images, full-site-editing, block-patterns, wide-blocks, block-styles, accessibility-ready, responsive-layout
*/

/* All fonts self-hosted — no Google Fonts CDN dependency */

/* Syne — display/headings (700, 800) */
@font-face {
	font-family: 'Syne';
	font-style: normal;
	font-weight: 700 800;
	font-display: swap;
	src: url('assets/fonts/syne-latin-ext.woff2') format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: 'Syne';
	font-style: normal;
	font-weight: 700 800;
	font-display: swap;
	src: url('assets/fonts/syne-latin.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* DM Sans — body text (400, 500, 600 normal + 400 italic) */
@font-face {
	font-family: 'DM Sans';
	font-style: normal;
	font-weight: 400 600;
	font-display: swap;
	src: url('assets/fonts/dm-sans-latin-ext.woff2') format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: 'DM Sans';
	font-style: normal;
	font-weight: 400 600;
	font-display: swap;
	src: url('assets/fonts/dm-sans-latin.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: 'DM Sans';
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src: url('assets/fonts/dm-sans-italic-latin-ext.woff2') format('woff2');
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: 'DM Sans';
	font-style: italic;
	font-weight: 400;
	font-display: swap;
	src: url('assets/fonts/dm-sans-italic-latin.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* JetBrains Mono — code blocks */
@font-face {
	font-family: 'JetBrains Mono';
	font-style: normal;
	font-weight: 100 800;
	font-display: swap;
	src: url('assets/fonts/jetbrains-mono-latin.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ==========================================================================
   CSS Custom Properties — COLDICP Brand Tokens
   ========================================================================== */
:root {
	/* Brand Colors */
	--wp--preset--color--base:         #F0F4D8;
	--wp--preset--color--contrast:     #1A1A18;
	--wp--preset--color--surface:      #F5F8E8;
	--wp--preset--color--primary:      #C8F135;
	--wp--preset--color--primary-dark: #2C2C2A;
	--wp--preset--color--surface-alt:  #EEF3D5;
	--wp--preset--color--amber:        #F1A035;
	--wp--preset--color--green:        #5A7A00;
	--wp--preset--color--line:         #DDE4C0;
	--wp--preset--color--ink-soft:     #3A3A38;
	--wp--preset--color--muted:        #6A6A68;
	--wp--preset--color--ink-faint:    #9A9A98;
	--wp--preset--color--white:        #ffffff;
	--wp--preset--color--footer:       #1A1A18;

	/* Semantic aliases */
	--c-brand:        #1A1A18;
	--c-brand-light:  #2C2C2A;
	--c-brand-wash:   #F0F4D8;
	--c-surface:      #F5F8E8;
	--c-surface-alt:  #EEF3D5;
	--c-lime:         #C8F135;
	--c-amber:        #F1A035;
	--c-green:        #5A7A00;
	--c-ink:          #1A1A18;
	--c-ink-soft:     #3A3A38;
	--c-ink-muted:    #6A6A68;
	--c-ink-faint:    #9A9A98;
	--c-line:         #DDE4C0;
	--c-white:        #ffffff;
	--c-card-shadow:  0 1px 12px rgba(0,0,0,0.06);
	--c-card-shadow-hover: 0 4px 20px rgba(0,0,0,0.10);

	/* Layout */
	--container-max: 1280px;
	--container-pad: clamp(16px, 5vw, 48px);
	--header-h:      60px;
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */
*, *::before, *::after {
	box-sizing: border-box;
}

body {
	margin: 0;
	background-color: var(--wp--preset--color--base);
	color: var(--wp--preset--color--contrast);
	font-family: 'DM Sans', system-ui, sans-serif;
	font-size: 1rem;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Syne', system-ui, sans-serif;
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.02em;
	text-wrap: balance;
	color: var(--wp--preset--color--contrast);
	margin-top: 0;
}

p, blockquote, figcaption, li {
	text-wrap: pretty;
}

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

a {
	color: var(--wp--preset--color--primary);
	transition: color 0.2s ease;
}

/* ==========================================================================
   Container — Universal Max-Width Wrapper
   ========================================================================== */
.container,
.post-hero__inner,
.archive-hero__inner,
.site-footer__container,
.single-post-layout-wrapper > .single-post-layout,
.search-results-wrapper {
	width: 100%;
	max-width: var(--container-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--container-pad);
	padding-right: var(--container-pad);
}

/* ==========================================================================
   Reading Progress Bar
   ========================================================================== */
#reading-progress-container {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 5px;
	z-index: 99999;
	pointer-events: none;
}

#reading-progress {
	height: 100%;
	width: 0;
	background: linear-gradient(90deg, #1A1A18, #C8F135);
	transition: width 0.1s ease-out;
}

/* ==========================================================================
   Site Header — Floating Capsule Navbar
   ========================================================================== */
.site-header {
	position: fixed;
	top: 20px;     /* 20px gap from viewport top — positioning is never touched by WP inline styles */
	left: 0;
	right: 0;
	z-index: 100;
	background: transparent;
	border-bottom: none;
	padding: 0 16px !important;
	transition: none;
}


/*
 * .site-header__inner  —  the 3-column flex row inside the sticky bar.
 *
 * LEFT  : .site-header__brand  (logo + site name, no shrink)
 * CENTER: .primary-navigation  (nav links, flex:1, centred)
 * RIGHT : .wp-block-html       (search + subscribe + dark toggle, no shrink)
 *
 * max-width + horizontal padding match every other page section so that
 * the logo/nav/actions are always pixel-aligned with the content below.
 */
.site-header__inner {
	width: 100%;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 24px !important;
	padding-right: 8px !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	box-sizing: border-box;
	height: 56px;
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 20px;
	border-radius: 9999px;
	background: rgba(255, 255, 255, 0.75);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	box-shadow:
		0 4px 6px -1px rgba(0, 0, 0, 0.02),
		0 10px 15px -3px rgba(0, 0, 0, 0.04),
		0 0 0 1px rgba(255, 255, 255, 0.60) inset,
		0 0 0 1px rgba(0, 0, 0, 0.03);
	transition: box-shadow 0.3s ease, background 0.3s ease;
}

.site-header.is-scrolled .site-header__inner {
	background: rgba(255, 255, 255, 0.92);
	box-shadow:
		0 4px 6px -1px rgba(0, 0, 0, 0.04),
		0 10px 15px -3px rgba(0, 0, 0, 0.08),
		0 0 0 1px rgba(255, 255, 255, 0.70) inset,
		0 0 0 1px rgba(0, 0, 0, 0.05);
}



/* Suppress WP-generated vertical padding on nested block groups */
.site-header .wp-block-group {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

/* --- LEFT: Brand (logo + site name) --- */
.site-header__brand {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	gap: 10px !important;  /* !important overrides WP blockGap inline style="gap:16px" */
}

.site-header__brand .wp-block-site-logo img {
	max-height: 36px;
	width: auto;
	display: block;
}

.site-header__brand .wp-block-site-title {
	margin: 0;
	font-size: 1.15rem !important;
	line-height: 1;
	white-space: nowrap;
}

.site-header__brand .wp-block-site-title a {
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	font-weight: 700;
	letter-spacing: -0.03em;
}

.site-header__brand .wp-block-site-title a:hover {
	color: var(--wp--preset--color--primary);
}

/* ==========================================================================
   Primary Navigation — CENTER column (wp_nav_menu output)
   ========================================================================== */

/* Nav pattern renders as .wp-block-html; flex-grow it to fill center */
.site-header__inner > .wp-block-html:has(.primary-navigation) {
	flex: 1 1 0%;
	min-width: 0;
	display: flex;
	justify-content: center;
}

.primary-navigation {
	display: flex;
	align-items: center;
}

.primary-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
}

.primary-nav__list > li {
	position: relative;
}

.primary-nav__list > li > a {
	display: block;
	position: relative;
	padding: 6px 12px;
	color: var(--c-body-text);
	font-weight: 500;
	font-size: 0.925rem;
	border-radius: 8px;
	transition: color 0.15s ease;
	text-decoration: none;
	white-space: nowrap;
}

.primary-nav__list > li > a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) scaleX(0);
	width: 16px;
	height: 2px;
	background: var(--wp--preset--color--primary);
	border-radius: 99px;
	transition: transform 0.2s ease;
	transform-origin: center;
}

.primary-nav__list > li > a:hover,
.primary-nav__list > li.current-menu-item > a,
.primary-nav__list > li.current-menu-ancestor > a,
.primary-nav__list > li.current-page-ancestor > a {
	color: var(--wp--preset--color--primary);
	background: transparent;
}

.primary-nav__list > li > a:hover::after,
.primary-nav__list > li.current-menu-item > a::after,
.primary-nav__list > li.current-menu-ancestor > a::after,
.primary-nav__list > li.current-page-ancestor > a::after {
	transform: translateX(-50%) scaleX(1);
}

/* Sub-menus */
.primary-nav__list .sub-menu {
	position: absolute;
	top: calc(100% + 6px);
	left: 0;
	list-style: none;
	margin: 0;
	padding: 8px;
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 14px;
	box-shadow: 0 16px 48px rgba(0, 0, 0, 0.12);
	min-width: 200px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-4px);
	transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
	z-index: 200;
}

.primary-nav__list > li:hover > .sub-menu,
.primary-nav__list > li:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.primary-nav__list .sub-menu a {
	display: block;
	padding: 8px 12px;
	color: var(--c-body-text);
	font-size: 0.9rem;
	border-radius: 8px;
	text-decoration: none;
	white-space: nowrap;
	transition: all 0.15s ease;
}

.primary-nav__list .sub-menu a:hover {
	color: var(--wp--preset--color--primary);
	background: var(--c-primary-a10);
}


@media (max-width: 900px) {
	.primary-navigation { display: none; }
}

/* ==========================================================================
   Mobile Menu — hamburger toggle + slide-down panel
   ========================================================================== */

/* Hide toggle on desktop */
.mobile-menu-toggle {
	display: none;
}

@media (max-width: 900px) {
	/* Show toggle on mobile */
	.mobile-menu-toggle {
		display: flex;
		align-items: center;
		justify-content: center;
		width: 40px;
		height: 40px;
		padding: 0;
		border: none;
		border-radius: 8px;
		background: transparent;
		color: var(--wp--preset--color--contrast);
		cursor: pointer;
		flex-shrink: 0;
		transition: background 0.15s ease, color 0.15s ease;
	}

	.mobile-menu-toggle:hover,
	.mobile-menu-toggle:focus-visible {
		background: rgba(128, 128, 128, 0.15);
		outline: 2px solid var(--wp--preset--color--primary);
		outline-offset: 2px;
	}

	/* Icon visibility — show hamburger, hide X by default */
	.mobile-menu-toggle__icon--close { display: none; }

	/* When expanded: show X, hide hamburger */
	.mobile-menu-toggle[aria-expanded="true"] .mobile-menu-toggle__icon--open  { display: none; }
	.mobile-menu-toggle[aria-expanded="true"] .mobile-menu-toggle__icon--close { display: block; }
}

/* Mobile menu panel — always dark overlay regardless of site theme */
.mobile-menu {
	display: none;
	position: fixed;
	top: 76px;
	left: 0;
	right: 0;
	z-index: 999;
	background: #0A0F1E; /* --navy — always dark */
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
	overflow-y: auto;
	max-height: calc(100vh - 76px);
	padding: 16px 0 32px;
}

.mobile-menu.is-open {
	display: block;
}

/* Prevent body scroll when menu is open */
body.menu-open {
	overflow: hidden;
}

/* Mobile nav list */
.mobile-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mobile-nav__list li {
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.mobile-nav__list li:first-child {
	border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.mobile-nav__list a {
	display: block;
	padding: 14px 24px;
	font-size: 1rem;
	font-weight: 500;
	color: #F1F5F9; /* always light — readable on dark navy */
	text-decoration: none;
	transition: color 0.15s ease, background 0.15s ease;
}

.mobile-nav__list a:hover,
.mobile-nav__list a:focus-visible {
	color: var(--wp--preset--color--primary);
	background: rgba(255, 255, 255, 0.05);
}

.mobile-nav__list .current-menu-item > a,
.mobile-nav__list .current-page-ancestor > a {
	color: var(--wp--preset--color--primary);
}

/* Sub-menu indented */
.mobile-nav__list .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	background: rgba(0, 0, 0, 0.2);
}

.mobile-nav__list .sub-menu a {
	padding-left: 40px;
	font-size: 0.9rem;
	font-weight: 400;
	color: #94A3B8;
}

.mobile-nav__list .sub-menu a:hover {
	color: var(--wp--preset--color--primary);
}

/* ==========================================================================
   Newsletter Subscribe Modal (Popup)
   ========================================================================== */
.newsletter-modal {
	position: fixed;
	inset: 0;
	z-index: 9998;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

.newsletter-modal.is-open {
	opacity: 1;
	visibility: visible;
}

.newsletter-modal__backdrop {
	position: fixed;
	inset: 0;
	background: rgba(26, 26, 24, 0.60);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	cursor: pointer;
}

.newsletter-modal__panel {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, calc(-50% + 24px)) scale(0.96);
	z-index: 9999;
	background: #F0F4D8;
	border: 1.5px solid rgba(200, 241, 53, 0.40);
	border-radius: 24px;
	padding: 52px 44px 44px;
	max-width: 480px;
	width: calc(100% - 32px);
	text-align: center;
	box-shadow: 0 32px 80px rgba(26, 26, 24, 0.20);
	transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.newsletter-modal.is-open .newsletter-modal__panel {
	transform: translate(-50%, -50%) scale(1);
}

.newsletter-modal__close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 34px;
	height: 34px;
	padding: 0;
	background: rgba(26, 26, 24, 0.08);
	border: 1px solid rgba(26, 26, 24, 0.12);
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #1A1A18;
	transition: background 0.15s ease;
}

.newsletter-modal__close:hover {
	background: rgba(26, 26, 24, 0.16);
}

.newsletter-modal__icon {
	width: 60px;
	height: 60px;
	background: #1A1A18;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
	color: #C8F135;
}

.newsletter-modal__eyebrow {
	display: inline-block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: #5A7A00;
	background: rgba(200, 241, 53, 0.28);
	border: 1px solid rgba(200, 241, 53, 0.55);
	border-radius: 999px;
	padding: 4px 14px;
	margin-bottom: 16px;
}

.newsletter-modal__title {
	font-family: 'Syne', sans-serif;
	font-size: clamp(1.4rem, 4vw, 1.8rem);
	font-weight: 700;
	color: #1A1A18;
	line-height: 1.2;
	margin-bottom: 12px;
}

.newsletter-modal__desc {
	font-family: 'DM Sans', sans-serif;
	font-size: 0.95rem;
	color: rgba(26, 26, 24, 0.65);
	line-height: 1.65;
	margin-bottom: 28px;
}

.newsletter-modal__form {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.newsletter-modal__input {
	width: 100%;
	padding: 13px 18px;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.95rem;
	border: 1.5px solid rgba(26, 26, 24, 0.18);
	border-radius: 10px;
	background: #fff;
	color: #1A1A18;
	outline: none;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
	box-sizing: border-box;
}

.newsletter-modal__input:focus {
	border-color: #C8F135;
	box-shadow: 0 0 0 3px rgba(200, 241, 53, 0.28);
}

.newsletter-modal__input::placeholder {
	color: rgba(26, 26, 24, 0.40);
}

.newsletter-modal__submit {
	width: 100%;
	padding: 14px 24px;
	font-family: 'Syne', sans-serif;
	font-size: 1rem;
	font-weight: 700;
	background: #1A1A18;
	color: #C8F135;
	border: none;
	border-radius: 10px;
	cursor: pointer;
	transition: background 0.15s ease, transform 0.1s ease;
}

.newsletter-modal__submit:hover {
	background: #2d2d2b;
	transform: translateY(-1px);
}

.newsletter-modal__note {
	font-family: 'DM Sans', sans-serif;
	font-size: 0.78rem;
	color: rgba(26, 26, 24, 0.45);
	margin-top: 14px;
	margin-bottom: 0 !important;
}

body.popup-open { overflow: hidden; }

@media (max-width: 520px) {
	.newsletter-modal__panel {
		padding: 44px 22px 36px;
		border-radius: 18px;
		width: calc(100% - 24px);
	}
	.newsletter-modal__title {
		font-size: 1.35rem;
	}
}

/* ==========================================================================
   Header Actions — RIGHT column (search + subscribe + dark mode toggle)
   ========================================================================== */

/* The wp:html block wrapping header-actions.php outputs .wp-block-html.
   Give it flex:0 so it never grows/shrinks and stays pinned to the right. */
.site-header__inner > .wp-block-html {
	flex: 0 0 auto;
}

.site-header__actions {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-shrink: 0;
}

.header-search-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 10px;
	cursor: pointer;
	color: var(--c-body-text);
	transition: all 0.15s ease;
	padding: 0;
}

.header-search-toggle:hover {
	background: var(--wp--preset--color--surface);
	border-color: var(--wp--preset--color--border);
	color: var(--wp--preset--color--contrast);
}

.header-subscribe-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	height: 36px;
	padding: 0 18px;
	background: var(--wp--preset--color--primary);
	color: #fff !important;
	border-radius: 999px;
	font-size: 0.85rem;
	font-weight: 600;
	text-decoration: none;
	transition: all 0.2s ease;
	white-space: nowrap;
}

.header-subscribe-btn:hover {
	background: var(--wp--preset--color--primary-dark);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(255, 92, 53, 0.3);
}

/* Search panel dropdown */
.header-search-panel {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--wp--preset--color--base);
	border-top: 1px solid var(--wp--preset--color--border);
	border-bottom: 1px solid var(--wp--preset--color--border);
	padding: 16px var(--container-pad);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.10);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.header-search-panel[aria-hidden="true"] {
	opacity: 0;
	pointer-events: none;
	transform: translateY(-4px);
}

.header-search-panel[aria-hidden="false"] {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.header-search-panel .search-form {
	max-width: 600px;
	margin: 0 auto;
}







/* ==========================================================================
   Button System
   ========================================================================== */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: all 0.2s ease;
	border-radius: 999px;
}

.btn--primary {
	background: #1A1A18;
	color: #C8F135;
	padding: 12px 24px;
	font-size: 0.9rem;
}

.btn--primary:hover {
	background: #2A2A26;
	color: #C8F135;
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(26,26,24,0.25);
}

.btn--sm {
	padding: 9px 18px;
	font-size: 0.82rem;
}

.btn--outline {
	background: transparent;
	color: #1A1A18;
	border: 1.5px solid rgba(26,26,24,0.30);
	padding: 11px 24px;
	font-size: 0.9rem;
}

.btn--outline:hover {
	border-color: #1A1A18;
	background: rgba(26,26,24,0.06);
}

/* ==========================================================================
   Post Hero — Dark Single Post Header
   ========================================================================== */
.post-hero {
	background: var(--c-brand-wash);
	background-image: linear-gradient(180deg, rgba(200,241,53,0.15) 0%, transparent 100%);
	color: var(--c-ink);
	position: relative;
	overflow: hidden;
	text-align: center;
}

.post-hero__inner {
	padding-top: calc(76px + clamp(40px, 6vw, 64px));
	padding-bottom: clamp(32px, 5vw, 48px);
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
	z-index: 1;
	max-width: 800px;
	margin: 0 auto;
	padding-left: clamp(16px, 5vw, 40px);
	padding-right: clamp(16px, 5vw, 40px);
}

/* Category eyebrow — white pill with lime dot (matches reference) */
.post-hero__categories {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 28px;
	justify-content: center;
}

.post-hero__eyebrow-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 5px 14px;
	border-radius: 999px;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	background: #fff;
	color: var(--c-ink-60);
	border: 1px solid #DDE4C0;
	transition: border-color 0.15s ease;
}

.post-hero__eyebrow-badge:hover {
	border-color: #BED080;
	color: var(--c-ink);
}

.post-hero__eyebrow-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #C8F135;
	flex-shrink: 0;
}

/* Post card category badges (lime tinted — used in card grid) */
.category-badge,
.category-badge--dark,
.category-badge--light {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 14px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-decoration: none;
	transition: all 0.15s ease;
	background: rgba(200,241,53,0.18);
	color: #5A7A00;
	border: 1px solid rgba(200,241,53,0.4);
}

.category-badge:hover,
.category-badge--dark:hover,
.category-badge--light:hover {
	background: rgba(200,241,53,0.32);
	color: #3d5700;
}

/* Hero Title */
.post-hero__title {
	font-size: clamp(2.25rem, 5vw, 3.5rem);
	font-weight: 700;
	line-height: 1.08;
	letter-spacing: -0.035em;
	color: var(--c-ink);
	margin-bottom: 28px;
	font-family: 'Syne', system-ui;
}

/* Meta row — inline flex with dot separators */
.post-hero__meta {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	justify-content: center;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--c-ink-60);
}

.post-hero__author-link {
	display: block;
	flex-shrink: 0;
	text-decoration: none;
}

.post-hero__author-link img {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid #DDE4C0;
}

.post-hero__author-name {
	font-weight: 600;
	color: var(--c-ink);
}

.post-hero__author-name a {
	color: inherit;
	text-decoration: none;
}

.post-hero__author-name a:hover { color: #5A7A00; }

.post-hero__meta-dot {
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: #DDE4C0;
	flex-shrink: 0;
}

.post-hero__meta-date,
.post-hero__meta-read {
	color: var(--c-ink-60);
}

/* Hero image — full-width below header, outer container controls max-width */
.post-hero__image-outer {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 clamp(16px, 5vw, 40px) 0;
}

.post-hero__image-wrap {
	position: relative;
	border-radius: 24px;
	overflow: hidden;
	border: 1px solid #DDE4C0;
	box-shadow: 0 12px 48px rgba(26,26,24,0.10);
}

.post-hero__image-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 120px;
	background: linear-gradient(0deg, rgba(240,244,216,0.85) 0%, transparent 100%);
	pointer-events: none;
}

.post-hero__image {
	width: 100%;
	height: 420px;
	object-fit: cover;
	display: block;
	cursor: zoom-in;
	transition: transform 0.4s ease;
}

.post-hero__image:hover {
	transform: scale(1.02);
}

@media (max-width: 768px) {
	.post-hero__image { height: 220px; }
	.post-hero__image-wrap { border-radius: 16px; }
}

/* ==========================================================================
   Lightbox — Feature image zoom overlay
   ========================================================================== */
.coldicp-lightbox {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 99999;
	align-items: center;
	justify-content: center;
}

.coldicp-lightbox.is-open {
	display: flex;
}

.coldicp-lightbox__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.92);
	cursor: zoom-out;
}

.coldicp-lightbox__img {
	position: relative;
	max-width: 92vw;
	max-height: 90vh;
	object-fit: contain;
	border-radius: 8px;
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6);
	cursor: zoom-out;
}

.coldicp-lightbox__close {
	position: absolute;
	top: 20px;
	right: 24px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.20);
	color: #fff;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s ease;
}

.coldicp-lightbox__close:hover,
.coldicp-lightbox__close:focus-visible {
	background: rgba(255, 255, 255, 0.22);
	outline: 2px solid rgba(255, 255, 255, 0.4);
	outline-offset: 2px;
}

@media (max-width: 640px) {
	.post-hero__image-wrap {
		border-radius: 16px;
	}
}

/* ==========================================================================
   Archive Hero — Dark Gradient (blog listing, category, tag)
   ========================================================================== */
.archive-hero {
	background: var(--c-brand-wash);
	color: var(--c-ink);
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: stretch;
}

.archive-hero::before {
	content: '';
	position: absolute;
	inset-inline: 0;
	top: 0;
	height: 100%;
	background: linear-gradient(180deg, rgba(200,241,53,0.18) 0%, rgba(210,238,60,0.06) 55%, transparent 100%);
	pointer-events: none;
}

.archive-hero__inner {
	padding-top: calc(76px + clamp(56px, 8vw, 96px));
	padding-bottom: clamp(48px, 6vw, 72px);
	position: relative;
	z-index: 1;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.archive-hero__eyebrow {
	font-family: 'DM Sans', system-ui;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #6A6A68;
	margin-bottom: 16px;
	display: block;
}

.archive-hero__eyebrow-dot {
	display: none;
}

@keyframes pulse-dot {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.4; }
}

.archive-hero__title {
	font-family: 'Syne', system-ui;
	font-size: clamp(3rem, 7vw, 4.5rem);
	font-weight: 700;
	letter-spacing: -0.05em;
	line-height: 1.05;
	margin-bottom: 24px;
	color: #1A1A18;
	text-align: center;
}

.archive-hero__title span {
	background: #C8F135;
	padding: 2px 8px;
	border-radius: 6px;
	display: inline-block;
}

.archive-hero__subtitle {
	font-family: 'DM Sans', system-ui;
	font-size: 1.125rem;
	color: #3A3A38;
	max-width: 672px;
	margin: 0 auto 48px auto;
	line-height: 1.7;
	text-align: center;
}

/* Category filter pills */
.archive-hero__filter {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
	justify-content: center;
}

.filter-pill {
	display: inline-flex;
	align-items: center;
	padding: 8px 20px;
	border-radius: 999px;
	font-size: 0.8125rem;
	font-weight: 600;
	text-decoration: none;
	border: 1px solid #DDE4C0;
	color: #6A6A68;
	background: #fff;
	transition: all 0.2s ease;
}

.filter-pill:hover {
	background: rgba(200,241,53,0.15);
	border-color: #BED080;
	color: var(--c-ink);
}

.filter-pill--active {
	background: var(--c-ink);
	border-color: var(--c-ink);
	color: #C8F135;
	font-weight: 600;
}

.filter-pill--active:hover {
	background: #2d2d2b;
	border-color: #2d2d2b;
	color: #C8F135;
}

/* ==========================================================================
   3-Column Single Post Layout
   ========================================================================== */
.single-post-layout-wrapper {
	background: var(--c-brand-wash);
}

.single-post-layout {
	display: grid;
	grid-template-columns: 240px minmax(0, 1fr) 300px;
	gap: 48px;
	padding-top: 48px;
	padding-bottom: 64px;
	align-items: start;
}

.single-post-layout__toc {
	position: sticky;
	top: calc(var(--header-h) + 24px);
	max-height: calc(100vh - var(--header-h) - 48px);
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: #DDE4C0 transparent;
}

.single-post-layout__toc::-webkit-scrollbar { width: 3px; }
.single-post-layout__toc::-webkit-scrollbar-thumb {
	background: var(--wp--preset--color--border);
	border-radius: 4px;
}

.single-post-layout__content {
	min-width: 0;
}

.single-post-layout__affiliate {
	position: sticky;
	top: calc(var(--header-h) + 24px);
}

/* no-toc: hide left column */
.single-post-layout.no-toc {
	grid-template-columns: minmax(0, 1fr) 260px;
}

@media (max-width: 1200px) {
	.single-post-layout {
		grid-template-columns: 180px minmax(0, 1fr) 240px;
		gap: 40px;
	}
}

@media (max-width: 1024px) {
	.single-post-layout {
		grid-template-columns: 1fr;
		gap: 32px;
		padding-top: 32px;
		padding-bottom: 48px;
	}

	.single-post-layout__toc,
	.single-post-layout__affiliate {
		position: static;
		top: auto;
		max-height: none;
	}

	.single-post-layout__affiliate { order: 3; }
}

@media (max-width: 768px) {
	.single-post-layout__toc { display: none; }
	.single-post-layout.no-toc { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Table of Contents (TOC) Sidebar
   ========================================================================== */
.toc-sidebar__inner {
	padding: 20px;
	background: #fff;
	border-radius: 14px;
	border: 1px solid #DDE4C0;
}


.toc-sidebar__title {
	display: flex;
	align-items: center;
	gap: 7px;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--c-ink-60);
	margin: 0 0 14px;
}

.toc-sidebar__title svg {
	width: 13px;
	height: 13px;
	flex-shrink: 0;
}

.toc-list {
	list-style: none;
	padding: 0;
	margin: 0;
	border-left: 2px solid #DDE4C0;
}

.toc-item {
	margin: 0;
	padding: 0;
}

.toc-link {
	display: block;
	padding: 6px 0 6px 14px;
	font-size: 0.82rem;
	color: var(--c-ink-60);
	text-decoration: none;
	line-height: 1.4;
	border-left: 2px solid transparent;
	margin-left: -2px;
	transition: color 0.15s ease, border-color 0.15s ease;
}

.toc-link:hover {
	color: var(--c-ink);
}

.toc-link.is-active {
	color: var(--c-ink);
	border-left-color: #C8F135;
	font-weight: 600;
}

.toc-item--h3 .toc-link {
	padding-left: 26px;
	font-size: 0.78rem;
}

/* TOC sidebar wrapper — contains TOC + newsletter widget */
.toc-sidebar-wrap {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

/* TOC newsletter widget — dark card below TOC */
.toc-newsletter {
	background: var(--c-ink);
	border-radius: 16px;
	padding: 20px;
	color: #fff;
}

.toc-newsletter__label {
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	color: #C8F135;
	margin: 0 0 8px;
	font-family: 'DM Sans', system-ui;
}

.toc-newsletter__text {
	font-size: 0.82rem;
	font-weight: 500;
	color: rgba(255,255,255,0.75);
	margin: 0 0 14px;
	line-height: 1.5;
	font-family: 'DM Sans', system-ui;
}

.toc-newsletter__form {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.toc-newsletter__input {
	width: 100%;
	background: rgba(255,255,255,0.08);
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 8px;
	padding: 9px 12px;
	font-size: 0.78rem;
	color: #fff;
	outline: none;
	transition: border-color 0.15s ease;
	font-family: 'DM Sans', system-ui;
}

.toc-newsletter__input::placeholder { color: rgba(255,255,255,0.35); }

.toc-newsletter__input:focus {
	border-color: #C8F135;
}

.toc-newsletter__btn {
	width: 100%;
	background: #C8F135;
	color: var(--c-ink);
	border: none;
	border-radius: 8px;
	padding: 9px 14px;
	font-size: 0.78rem;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.15s ease;
	font-family: 'DM Sans', system-ui;
}

.toc-newsletter__btn:hover { background: #D4F55A; }

/* ==========================================================================
   Article Body Typography
   ========================================================================== */
.wp-block-post-content {
	font-size: 1.075rem;
	line-height: 1.8;
	color: var(--c-body-text);
}

.wp-block-post-content > * + * {
	margin-top: 0;
}

.wp-block-post-content h2 {
	font-size: 2rem;
	margin-top: 3rem;
	margin-bottom: 1.25rem;
	line-height: 1.15;
	letter-spacing: -0.03em;
	font-family: 'Syne', system-ui;
	color: var(--c-ink);
}

.wp-block-post-content h3 {
	font-size: clamp(1.15rem, 2vw, 1.375rem);
	margin-top: 2.25rem;
	margin-bottom: 0.75rem;
	font-family: 'Syne', system-ui;
	color: var(--c-ink);
}

.wp-block-post-content h4 {
	font-size: 1.1rem;
	margin-top: 1.75rem;
	margin-bottom: 0.5rem;
}

.wp-block-post-content p { margin-bottom: 1.5rem; }

.wp-block-post-content a {
	color: #5A7A00;
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1.5px;
}

.wp-block-post-content a:hover {
	color: #3d5700;
}

.wp-block-post-content ul,
.wp-block-post-content ol {
	padding-left: 1.5rem;
	margin-bottom: 1.5rem;
}

.wp-block-post-content li { margin-bottom: 6px; }

.wp-block-post-content strong { font-weight: 600; color: #1A1A18; }

.wp-block-post-content em { font-style: italic; }

/* Blockquote */
.wp-block-quote {
	border-left: 4px solid #C8F135 !important;
	margin: 2rem 0;
	padding: 1.5rem 2rem;
	background: rgba(200,241,53,0.08);
	border-radius: 0 12px 12px 0;
}

.wp-block-quote p {
	font-size: 1.15rem;
	font-weight: 500;
	color: var(--c-ink);
	line-height: 1.5;
	margin-bottom: 0 !important;
	font-style: italic;
}

.wp-block-quote cite,
.wp-block-quote footer {
	display: block;
	margin-top: 10px;
	font-size: 0.875rem;
	color: var(--c-ink-60);
	font-style: normal;
	font-weight: 600;
}

/* Code */
.wp-block-code {
	background: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 10px;
	font-family: "JetBrains Mono", "SF Mono", Monaco, monospace;
	font-size: 0.88rem;
	padding: 1.25rem 1.5rem;
	overflow-x: auto;
}


code {
	font-family: "JetBrains Mono", "SF Mono", Monaco, monospace;
	font-size: 0.875em;
	background: var(--wp--preset--color--surface);
	color: var(--wp--preset--color--primary);
	padding: 2px 6px;
	border-radius: 4px;
}


/* Table */
.wp-block-post-content table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.9rem;
	margin-bottom: 2rem;
}

.wp-block-post-content th {
	background: var(--wp--preset--color--surface);
	font-weight: 600;
	text-align: left;
	padding: 10px 14px;
	border-bottom: 2px solid var(--wp--preset--color--border);
}

.wp-block-post-content td {
	padding: 10px 14px;
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.wp-block-post-content tr:hover td {
	background: var(--wp--preset--color--surface);
}

/* ==========================================================================
   Post Meta Row
   ========================================================================== */
.post-meta {
	margin-bottom: 24px;
}

.post-meta__categories {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 16px;
}

.post-meta__category-badge {
	display: inline-flex;
	align-items: center;
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	background: var(--c-primary-a10);
	color: var(--wp--preset--color--primary);
	border: 1px solid rgba(255, 92, 53, 0.2);
	transition: all 0.15s ease;
}

.post-meta__category-badge:hover {
	background: var(--wp--preset--color--primary);
	color: #fff;
}

.post-meta__author-row {
	display: flex;
	align-items: center;
	gap: 12px;
}

.post-meta__author-link {
	display: block;
	flex-shrink: 0;
	text-decoration: none;
}

.post-meta__avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--wp--preset--color--border);
	display: block;
}

.post-meta__author-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.post-meta__author-name {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
}

.post-meta__author-name:hover {
	color: var(--wp--preset--color--primary);
}

.post-meta__details {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 0.8rem;
	color: var(--wp--preset--color--muted);
}

.post-meta__separator {
	opacity: 0.5;
}

.post-meta__date {
	color: var(--wp--preset--color--muted);
}

/* Reading time badge */
.reading-time {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.8rem;
	color: var(--wp--preset--color--muted);
}

.reading-time svg {
	width: 13px;
	height: 13px;
	flex-shrink: 0;
}

/* ==========================================================================
   Post Cards Grid
   ========================================================================== */
.wp-block-post-template.post-cards-grid {
	gap: 28px;
}

/*
 * WordPress renders wp:post-template as a <ul> with <li> grid items.
 * The .post-card sits inside the <li>, so it needs height:100% to fill it.
 */
.wp-block-post-template.post-cards-grid > li {
	display: flex;
	flex-direction: column;
}


/* Blog Cards Grid */
.post-cards-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

@media (max-width: 1024px) {
	.post-cards-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}
}

@media (max-width: 640px) {
	.post-cards-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

/* Blog Card */
.blog-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 20px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.blog-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(0,0,0,0.08);
	border-color: #C8F135;
}

.blog-card__image {
	aspect-ratio: 16/10;
	background: #F5F8E8;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.blog-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
	display: block;
}

.blog-card:hover .blog-card__image img {
	transform: scale(1.04);
}

.blog-card__image-placeholder {
	font-size: 6rem;
	color: rgba(26,26,24,0.10);
}

.blog-card__content {
	padding: 32px;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
}

.blog-card__meta {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
}

.blog-card__category {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #6A6A68;
}

.blog-card__dot {
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: #DDE4C0;
	flex-shrink: 0;
}

.blog-card__read-time {
	font-size: 13px;
	color: #6A6A68;
}

.blog-card__title {
	font-family: 'Syne', system-ui;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.2;
	margin-bottom: 16px;
}

.blog-card__title a {
	text-decoration: none;
	color: #1A1A18;
	transition: color 0.15s ease;
}

.blog-card__title a:hover {
	color: #5A7A00;
}

.blog-card__excerpt {
	font-size: 0.875rem;
	color: #3A3A38;
	line-height: 1.7;
	margin-bottom: 24px;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex-grow: 1;
}

.blog-card__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 0.875rem;
	font-weight: 700;
	text-decoration: none;
	color: #1A1A18;
	transition: gap 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.blog-card__link:hover {
	gap: 12px;
}

.blog-card__link i {
	font-size: 1rem;
}
.post-card--dark {
	background: var(--wp--preset--color--dark-surface);
	border-color: rgba(255, 255, 255, 0.08);
	color: #fff;
}

.post-card--dark .post-card__title a {
	color: #fff;
}

/* Grid layouts */
.post-cards-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}

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

@media (max-width: 1024px) {
	.post-cards-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
	.post-cards-grid { grid-template-columns: 1fr; }
	.post-cards-grid--2 { grid-template-columns: 1fr; }
}

/* View-all link */
.view-all-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.875rem;
	font-weight: 600;
	color: #5A7A00;
	text-decoration: none;
	white-space: nowrap;
	transition: gap 0.2s ease;
}

.view-all-link:hover {
	gap: 10px;
	color: #3d5700;
}

/* ==========================================================================
   Affiliate Sidebar — Dark Tool Cards
   ========================================================================== */
.affiliate-sidebar {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.affiliate-sidebar__title {
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--c-ink-60);
	margin-bottom: 14px;
}

.affiliate-tools {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.affiliate-tool-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 16px;
	color: var(--c-ink);
	position: relative;
	overflow: hidden;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.affiliate-tool-card:hover {
	border-color: #C8F135;
	box-shadow: 0 4px 20px rgba(26,26,24,0.07);
}

.affiliate-tool-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 999px;
	margin-bottom: 12px;
}

.affiliate-tool-card__badge--recommended {
	background: rgba(200,241,53,0.18);
	color: #5A7A00;
	border: 1px solid rgba(200,241,53,0.4);
}

.affiliate-tool-card__badge--best-value {
	background: rgba(241,160,53,0.12);
	color: #b56a00;
	border: 1px solid rgba(241,160,53,0.3);
}

.affiliate-tool-card__header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 10px;
}

/* Letter-badge icon: colored square with bold first letter */
.affiliate-tool-card__icon {
	width: 38px;
	height: 38px;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	font-weight: 800;
	font-family: 'Syne', system-ui;
	flex-shrink: 0;
	color: #fff;
	text-transform: uppercase;
}

.affiliate-tool-card__title-wrap {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.affiliate-tool-card__name {
	font-size: 0.92rem;
	font-weight: 700;
	color: var(--c-ink);
	margin: 0;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	font-family: 'Syne', system-ui;
}

.affiliate-tool-card__price {
	font-size: 0.75rem;
	font-weight: 600;
	color: #5A7A00;
}

.affiliate-tool-card__desc {
	font-size: 0.8rem;
	color: var(--c-ink-60);
	line-height: 1.5;
	margin-bottom: 14px;
}

.affiliate-tool-card__cta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	padding: 9px 14px;
	border-radius: 10px;
	background: #1A1A18;
	color: #C8F135;
	font-size: 0.8rem;
	font-weight: 700;
	font-family: 'DM Sans', system-ui;
	text-decoration: none;
	transition: background 0.15s ease, color 0.15s ease;
}

.affiliate-tool-card__cta:hover {
	background: #2e2e2b;
	color: #d6ff3a;
}

/* Lime CTA box at bottom of sidebar */
.affiliate-sidebar__cta-box {
	margin-top: 20px;
	background: #C8F135;
	border-radius: 16px;
	padding: 24px 20px 20px;
	text-align: center;
}

.affiliate-sidebar__cta-icon {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #1A1A18;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
	box-shadow: 0 4px 16px rgba(26,26,24,0.30);
	font-size: 1.1rem;
	color: #C8F135;
}

.affiliate-sidebar__cta-box h3 {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--c-ink);
	margin: 0 0 8px;
	font-family: 'Syne', system-ui;
	letter-spacing: -0.025em;
}

.affiliate-sidebar__cta-box p {
	font-size: 0.875rem;
	color: rgba(26,26,24,0.65);
	margin: 0 0 20px;
	line-height: 1.6;
}

.affiliate-sidebar__cta-box a {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	padding: 12px 20px;
	background: var(--c-ink);
	color: #fff;
	border-radius: 12px;
	font-size: 0.875rem;
	font-weight: 700;
	text-decoration: none;
	transition: background 0.2s ease;
	box-shadow: 0 4px 16px rgba(26,26,24,0.25);
}

.affiliate-sidebar__cta-box a:hover {
	background: #2d2d2b;
	color: #fff;
}

/* ==========================================================================
   Breadcrumbs
   ========================================================================== */
.breadcrumbs {
	font-size: 0.82rem;
	margin-bottom: 18px;
}

.breadcrumbs__list {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 4px;
	list-style: none;
	padding: 0;
	margin: 0;
}

.breadcrumbs__item {
	display: flex;
	align-items: center;
	gap: 4px;
}

.breadcrumbs__item::after {
	content: '/';
	color: currentColor;
	opacity: 0.35;
	font-size: 0.78rem;
}

.breadcrumbs__item:last-child::after { display: none; }

.breadcrumbs__link {
	color: var(--wp--preset--color--muted);
	text-decoration: none;
	transition: color 0.15s ease;
}

.breadcrumbs__link:hover { color: var(--wp--preset--color--primary); }

.breadcrumbs__current {
	color: var(--wp--preset--color--muted);
	opacity: 0.65;
}

/* Dark context breadcrumbs */
.breadcrumbs--dark .breadcrumbs__link { color: rgba(255,255,255,0.5); }
.breadcrumbs--dark .breadcrumbs__link:hover { color: #fff; }
.breadcrumbs--dark .breadcrumbs__current { color: rgba(255,255,255,0.4); }

/* ==========================================================================
   Social Sharing
   ========================================================================== */
.social-sharing {
	display: flex;
	align-items: center;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
	padding: 24px 0;
	border-top: 1px solid var(--wp--preset--color--border);
}

.social-sharing__label {
	font-size: 0.78rem;
	font-weight: 700;
	color: var(--wp--preset--color--muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	white-space: nowrap;
}

.social-sharing__buttons {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.share-btn {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 8px 16px;
	background: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 9px;
	font-size: 0.82rem;
	font-weight: 600;
	cursor: pointer;
	text-decoration: none;
	color: var(--c-body-text);
	transition: all 0.2s ease;
}

.share-btn:hover {
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	background: var(--c-primary-a10);
}

.share-btn svg {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
}

.share-btn--twitter:hover  { color: #1DA1F2; border-color: #1DA1F2; background: rgba(29,161,242,0.06); }
.share-btn--linkedin:hover { color: #0A66C2; border-color: #0A66C2; background: rgba(10,102,194,0.06); }
.share-btn--facebook:hover { color: #1877F2; border-color: #1877F2; background: rgba(24,119,242,0.06); }
.share-btn--copy:hover     { color: var(--wp--preset--color--secondary); border-color: var(--wp--preset--color--secondary); background: rgba(0,255,148,0.06); }

/* ==========================================================================
   Related Posts — Keep Reading
   ========================================================================== */
.related-posts__header {
	text-align: center;
	margin-bottom: 48px;
}

.related-posts__eyebrow {
	font-family: 'DM Sans', system-ui;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #6A6A68;
	margin: 0 0 12px;
}

.related-posts__title {
	font-family: 'Syne', system-ui;
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	font-weight: 700;
	letter-spacing: -0.035em;
	color: #1A1A18;
	line-height: 1.1;
	margin: 0;
}

.related-posts__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

@media (max-width: 900px) {
	.related-posts__grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
}

@media (max-width: 600px) {
	.related-posts__grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Newsletter Section
   ========================================================================== */
.newsletter-section {
	background: linear-gradient(135deg, var(--wp--preset--color--void) 0%, var(--wp--preset--color--navy) 100%);
	position: relative;
	overflow: hidden;
}

.newsletter-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 60% 50%, rgba(0, 194, 255, 0.08), transparent 60%);
	pointer-events: none;
}

.newsletter-inner {
	position: relative;
	z-index: 1;
	text-align: center;
}

.newsletter-icon {
	width: 56px;
	height: 56px;
	background: rgba(255, 92, 53, 0.15);
	border: 1px solid rgba(255, 92, 53, 0.25);
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
	color: var(--wp--preset--color--primary);
}

.newsletter-title {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.1;
	color: #fff;
	margin-bottom: 14px;
}

.newsletter-desc {
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.6);
	max-width: 500px;
	margin: 0 auto 32px;
	line-height: 1.65;
}

.newsletter-form {
	max-width: 500px;
	margin: 0 auto;
}

.newsletter-form__names {
	display: flex;
	gap: 10px;
	margin-bottom: 10px;
}

.newsletter-form__name-input {
	flex: 1;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 10px;
	padding: 11px 14px;
	font-size: 0.95rem;
	color: #fff;
	min-width: 0;
	transition: border-color 0.15s ease;
}

.newsletter-form__name-input::placeholder { color: rgba(255, 255, 255, 0.4); }
.newsletter-form__name-input:focus {
	outline: none;
	border-color: rgba(255, 255, 255, 0.6);
	box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.12);
}

.newsletter-form__group {
	display: flex;
	gap: 0;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 14px;
	overflow: hidden;
	padding: 5px;
}

.newsletter-form__input {
	flex: 1;
	background: transparent;
	border: none;
	padding: 10px 14px;
	font-size: 0.95rem;
	color: #fff;
	min-width: 0;
}

.newsletter-form__input::placeholder { color: rgba(255, 255, 255, 0.4); }
.newsletter-form__input:focus { outline: none; }

/* Focus ring on the wrapper so keyboard users see a visible indicator */
.newsletter-form__group:focus-within {
	border-color: rgba(255, 255, 255, 0.5);
	box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.12);
}

.newsletter-form__submit {
	flex-shrink: 0;
	background: var(--wp--preset--color--primary);
	color: #fff;
	border: none;
	border-radius: 10px;
	padding: 10px 22px;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s ease;
	white-space: nowrap;
}

.newsletter-form__submit:hover {
	background: var(--wp--preset--color--primary-dark);
}

.newsletter-form__note {
	font-size: 0.78rem;
	color: rgba(255, 255, 255, 0.4);
	margin-top: 12px;
	text-align: center;
}

@media (max-width: 480px) {
	.newsletter-form__names,
	.newsletter-modal__names {
		flex-direction: column;
	}
}

/* Newsletter AJAX response messages */
.newsletter-response {
	margin-top: 12px;
	font-size: 0.875rem;
	border-radius: 6px;
	padding: 10px 14px;
	text-align: left;
}

.newsletter-response--success {
	color: var(--wp--preset--color--secondary);
	background: rgba(0, 255, 148, 0.08);
	border: 1px solid rgba(0, 255, 148, 0.2);
}

.newsletter-response--error {
	color: #ff6b6b;
	background: rgba(255, 107, 107, 0.08);
	border: 1px solid rgba(255, 107, 107, 0.2);
}

/* Honeypot — visually hidden, accessible to screen readers via aria-hidden */
.newsletter-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	opacity: 0;
	pointer-events: none;
	tab-size: 0;
}

/* ==========================================================================
   Search Form
   ========================================================================== */
.search-form {
	position: relative;
}

.search-form__wrapper {
	display: flex;
	align-items: center;
	background: var(--wp--preset--color--base);
	border: 1.5px solid var(--wp--preset--color--border);
	border-radius: 12px;
	overflow: hidden;
	transition: border-color 0.2s ease;
}

.search-form__wrapper:focus-within {
	border-color: var(--wp--preset--color--primary);
	box-shadow: 0 0 0 3px rgba(255, 92, 53, 0.1);
}

.search-form__icon {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	color: var(--wp--preset--color--muted);
	margin-left: 14px;
}

.search-field {
	flex: 1;
	padding: 12px 14px;
	border: none;
	background: transparent;
	color: var(--wp--preset--color--contrast);
	font-size: 0.95rem;
}

.search-field:focus { outline: none; }

.search-field::placeholder { color: var(--wp--preset--color--muted); }

.search-submit {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	background: var(--wp--preset--color--primary);
	color: #fff;
	border: none;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.2s ease;
	white-space: nowrap;
}

.search-submit:hover { background: var(--wp--preset--color--primary-dark); }

/* Search results header */
.search-results-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 24px;
	flex-wrap: wrap;
	margin-bottom: 40px;
	padding-bottom: 28px;
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.search-results-count {
	font-size: 1.05rem;
	color: var(--c-body-text);
	margin: 0;
}

.search-results-count strong { color: var(--c-ink); }
.search-results-count em { color: #5A7A00; font-style: normal; font-weight: 600; }

.search-results-new-search {
	width: 100%;
	max-width: 400px;
}

@media (max-width: 640px) {
	.search-results-header { flex-direction: column; }
	.search-results-new-search { max-width: 100%; }
}

/* ==========================================================================
   404 Page
   ========================================================================== */
.error-404 {
	min-height: 80vh;
	display: flex;
	align-items: center;
}

.error-404__inner {
	text-align: center;
	padding: clamp(48px, 8vw, 96px) 0;
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
}

.error-404__number {
	font-size: clamp(5rem, 15vw, 9rem);
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.05em;
	background: linear-gradient(135deg, #C8F135 0%, #BED080 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	display: block;
	margin-bottom: 16px;
	font-family: 'Syne', system-ui;
}

.error-404__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 700;
	color: #1A1A18;
	margin-bottom: 14px;
}

.error-404__message {
	font-size: 1.05rem;
	color: rgba(26,26,24,0.60);
	max-width: 480px;
	margin: 0 auto 36px;
	line-height: 1.65;
}

.error-404__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 40px;
}

.error-404__search {
	max-width: 480px;
	margin: 0 auto 48px;
}

.error-404__search-label {
	font-size: 0.875rem;
	color: rgba(26,26,24,0.55);
	margin-bottom: 12px;
}

.error-404__search .search-form__wrapper {
	background: rgba(255,255,255,0.80);
	border-color: rgba(26,26,24,0.15);
}

.error-404__popular {
	text-align: left;
	margin-top: 64px;
}

.error-404__popular-eyebrow {
	font-family: 'DM Sans', system-ui;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(26,26,24,0.55);
	margin-bottom: 8px;
	text-align: center;
}

.error-404__popular-title {
	font-size: clamp(1.25rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: #1A1A18;
	margin-bottom: 32px;
	text-align: center;
	letter-spacing: -0.03em;
}

/* ==========================================================================
   Site Footer
   ========================================================================== */
.site-footer {
	background: var(--wp--preset--color--mid-dark);
	color: rgba(255, 255, 255, 0.65);
}

.site-footer a {
	color: rgba(255, 255, 255, 0.55);
	text-decoration: none;
	transition: color 0.15s ease;
}

.site-footer a:hover { color: var(--wp--preset--color--primary); }

.site-footer__main {
	padding-top: clamp(48px, 7vw, 80px);
	padding-bottom: clamp(32px, 5vw, 56px);
}

.site-footer__container {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.site-footer__brand {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
}

/* Logo icon + site title inline row */
.site-footer__brand-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	color: #fff;
}

.site-footer__brand-link:hover {
	color: #fff;
	opacity: 0.85;
}

.site-footer__logo-icon {
	height: 36px;
	width: 36px;
	object-fit: contain;
	flex-shrink: 0;
	opacity: 0.9;
}

.site-footer__site-name {
	font-size: 1.2rem;
	font-weight: 700;
	color: #fff;
	letter-spacing: -0.02em;
}

.site-footer__tagline {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.65;
	max-width: 360px;
	margin: 0;
}

.site-footer__social {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: center;
}

.social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 9px;
	color: rgba(255, 255, 255, 0.55) !important;
	transition: all 0.2s ease;
}

.social-link:hover {
	background: rgba(255, 92, 53, 0.15);
	border-color: rgba(255, 92, 53, 0.3);
	color: var(--wp--preset--color--primary) !important;
}

/* Footer legal menu */
.site-footer__legal {
	margin-top: 4px;
}

.site-footer__legal-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 4px 16px;
}

.site-footer__legal-list li { margin: 0; }

.site-footer__legal-list li a,
.site-footer__legal-list a {
	font-size: 0.76rem;
	color: rgba(255, 255, 255, 0.3);
	text-decoration: none;
	letter-spacing: 0.01em;
	transition: color 0.15s ease;
}

.site-footer__legal-list li a:hover,
.site-footer__legal-list a:hover {
	color: rgba(255, 255, 255, 0.65);
}

/* Footer bottom bar */
.site-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	padding: 20px 0;
}

.site-footer__bottom .site-footer__container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	grid-template-columns: none;
}

.site-footer__copyright {
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.3);
	margin: 0;
}

.site-footer__built-with {
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.3);
	margin: 0;
}

.site-footer__built-with a {
	color: rgba(255, 255, 255, 0.4) !important;
}

.site-footer__built-with a:hover {
	color: var(--wp--preset--color--primary) !important;
}

/* Responsive footer */
@media (max-width: 640px) {
	.site-footer__bottom .site-footer__container {
		flex-direction: column;
		text-align: center;
	}
}

/* ==========================================================================
   Pagination
   ========================================================================== */
.wp-block-query-pagination {
	display: flex;
	gap: 8px;
	justify-content: center;
	align-items: center;
	margin-top: 56px;
	flex-wrap: wrap;
}

.wp-block-query-pagination-numbers a,
.wp-block-query-pagination-next a,
.wp-block-query-pagination-previous a,
.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 14px;
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 10px;
	color: var(--wp--preset--color--contrast);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.875rem;
	transition: all 0.2s ease;
}

.wp-block-query-pagination-numbers a:hover,
.wp-block-query-pagination-next a:hover,
.wp-block-query-pagination-previous a:hover,
.page-numbers:hover {
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
}

.page-numbers.current {
	background: var(--wp--preset--color--primary);
	border-color: var(--wp--preset--color--primary);
	color: #fff;
}

/* ==========================================================================
   Custom Block Styles
   ========================================================================== */
.is-style-card {
	background: var(--wp--preset--color--surface);
	border-radius: 12px;
	padding: var(--wp--preset--spacing--40);
	border: 1px solid var(--wp--preset--color--border);
}

.is-style-bordered {
	border-left: 4px solid var(--wp--preset--color--primary);
	padding-left: 1.5rem;
}

.is-style-checkmark ul {
	list-style: none;
	padding-left: 0;
}

.is-style-checkmark li::before {
	content: '✓';
	color: var(--wp--preset--color--primary);
	font-weight: 700;
	margin-right: 8px;
}

.is-style-outline .wp-block-button__link {
	background: transparent;
	color: var(--wp--preset--color--primary);
	border: 2px solid var(--wp--preset--color--primary);
}

.is-style-rounded img { border-radius: 999px; }

.wp-block-separator {
	border-color: var(--wp--preset--color--border);
	opacity: 1;
}

.wp-block-image img { border-radius: 8px; }

.wp-block-image figcaption {
	font-size: 0.82rem;
	color: var(--wp--preset--color--muted);
	text-align: center;
	margin-top: 8px;
}

/* Author bio block */
.author-bio-block.wp-block-post-author {
	display: flex;
	gap: 20px;
	padding: 28px;
	background: var(--wp--preset--color--surface);
	border-radius: 14px;
	border: 1px solid var(--wp--preset--color--border);
}

.wp-block-post-author__avatar img {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--wp--preset--color--border);
}

.wp-block-post-author__name {
	font-size: 1.05rem;
	font-weight: 700;
	margin: 0 0 4px;
}

.wp-block-post-author__bio {
	font-size: 0.9rem;
	color: var(--wp--preset--color--muted);
	margin: 0;
	line-height: 1.6;
}

/* ==========================================================================
   FAQ Section (coldicp/faq pattern)
   ========================================================================== */
.faq-section {
	margin: 48px 0;
}

.faq-section__title {
	font-size: clamp(1.4rem, 2.5vw, 1.9rem);
	font-weight: 700;
	margin-bottom: 28px;
	color: var(--wp--preset--color--contrast);
}

.faq-item {
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.faq-item:first-of-type {
	border-top: 1px solid var(--wp--preset--color--border);
}

.faq-item__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 0;
	font-size: 1rem;
	font-weight: 600;
	color: var(--wp--preset--color--contrast);
	cursor: pointer;
	list-style: none;
	user-select: none;
}

.faq-item__question::-webkit-details-marker { display: none; }

.faq-item__question span {
	flex: 1;
}

.faq-item__chevron {
	flex-shrink: 0;
	color: var(--wp--preset--color--muted);
	transition: transform 0.2s ease;
}

.faq-item[open] .faq-item__chevron {
	transform: rotate(180deg);
}

.faq-item[open] .faq-item__question {
	color: var(--wp--preset--color--primary);
}

.faq-item__answer {
	padding: 0 0 20px;
	color: var(--c-body-text, var(--wp--preset--color--muted));
	line-height: 1.7;
}

.faq-item__answer p {
	margin: 0;
}

/* ==========================================================================
   HowTo Section (coldicp/howto pattern)
   ========================================================================== */
.howto-section {
	margin: 48px 0;
}

.howto-section__header {
	margin-bottom: 32px;
}

.howto-section__title {
	font-size: clamp(1.4rem, 2.5vw, 1.9rem);
	font-weight: 700;
	color: var(--wp--preset--color--contrast);
	margin-bottom: 10px;
}

.howto-section__desc {
	color: var(--c-body-text, var(--wp--preset--color--muted));
	font-size: 1rem;
	margin: 0;
	line-height: 1.65;
}

.howto-section__steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.howto-step {
	display: flex;
	gap: 20px;
	padding: 24px 0;
	border-bottom: 1px solid var(--wp--preset--color--border);
}

.howto-step:first-child {
	border-top: 1px solid var(--wp--preset--color--border);
}

.howto-step__number {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--wp--preset--color--primary);
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 2px;
}

.howto-step__body {
	flex: 1;
	min-width: 0;
}

.howto-step__title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--wp--preset--color--contrast);
	margin: 0 0 6px;
}

.howto-step__desc {
	font-size: 0.9375rem;
	color: var(--c-body-text, var(--wp--preset--color--muted));
	margin: 0;
	line-height: 1.65;
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */
.text-gradient {
	background: linear-gradient(135deg, var(--wp--preset--color--primary), var(--wp--preset--color--primary-dark));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.text-neon-green { color: var(--wp--preset--color--secondary); }
.text-neon-blue  { color: var(--wp--preset--color--tertiary); }

.font-mono {
	font-family: "JetBrains Mono", "SF Mono", Monaco, monospace;
	letter-spacing: -0.01em;
}

/* ==========================================================================
   Accessibility
   ========================================================================== */
.skip-link {
	position: absolute;
	top: -100%;
	left: 0;
	padding: 12px 20px;
	background: var(--wp--preset--color--primary);
	color: #fff;
	z-index: 10000;
	text-decoration: none;
	font-weight: 600;
	border-radius: 0 0 8px 0;
	transition: top 0.1s ease;
}

.skip-link:focus { top: 0; }

:where(.wp-site-blocks *:focus-visible) {
	outline: 2px solid var(--wp--preset--color--primary);
	outline-offset: 2px;
	border-radius: 2px;
}

/* ==========================================================================
   Smooth Scroll + Selection
   ========================================================================== */
@media (prefers-reduced-motion: no-preference) {
	html {
		scroll-behavior: smooth;
		scroll-padding-top: calc(var(--header-h) + 24px);
	}
}

::selection {
	background: var(--wp--preset--color--primary);
	color: #fff;
}

/* ==========================================================================
   Mobile & Responsive — Global
   ========================================================================== */
@media (max-width: 782px) {
	.site-header .wp-block-site-title { font-size: 1rem !important; }
}

@media (max-width: 640px) {
	.site-header__actions .header-subscribe-btn { display: none; }
}

/* ==========================================================================
   Global — Remove WordPress automatic block-gap margins between sections
   ========================================================================== */
:where(.wp-site-blocks) > *,
main.wp-block-group > * {
	margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

/* ==========================================================================
   Global — Homepage WP block gap removal
   ========================================================================== */
body.home :where(.wp-site-blocks) > *,
body.home main.wp-block-group > * {
	margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

/* ==========================================================================
   Capsule Navbar
   ========================================================================== */
#page-blur {
	position: fixed;
	inset: 0;
	z-index: 49;
	background: rgba(220,232,160,0.10);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s;
}
#page-blur.active { opacity: 1; pointer-events: auto; }

#navbar {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 60;
	display: flex;
	justify-content: center;
	padding: 14px 0 0;
	background: transparent;
	transition: padding 0.4s cubic-bezier(0.4,0,0.2,1);
}

.nav-capsule {
	width: 44%;
	min-width: 340px;
	max-width: 600px;
	background: rgba(240,244,216,0.90);
	backdrop-filter: blur(24px) saturate(1.4);
	-webkit-backdrop-filter: blur(24px) saturate(1.4);
	border: 1px solid rgba(200,215,140,0.55);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 2px 20px rgba(0,0,0,0.07), inset 0 0 0 0.5px rgba(255,255,255,0.3);
	transition: box-shadow 0.38s ease, border-color 0.38s ease;
}
#navbar.scrolled .nav-capsule {
	background: rgba(238,243,208,0.98);
	border-color: #BED080;
	box-shadow: 0 6px 28px rgba(0,0,0,0.10), inset 0 0 0 0.5px rgba(255,255,255,0.4);
}

.capsule-topbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 7px 7px 7px 16px;
	gap: 12px;
}

.nav-logo {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: 'Syne', system-ui, sans-serif;
	font-weight: 700;
	font-size: 14px;
	color: var(--c-ink);
	text-decoration: none;
	letter-spacing: -0.02em;
	flex-shrink: 0;
}
.nav-logo:hover { color: var(--c-ink); text-decoration: none; }
.nav-logo-icon {
	width: 26px;
	height: 26px;
	background: #1A1A18;
	border-radius: 7px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	overflow: hidden;
	box-shadow: 0 2px 6px rgba(0,0,0,0.2);
}
.nav-logo-img__img {
	width: 18px;
	height: 18px;
	object-fit: contain;
	display: block;
}

.capsule-topbar-right {
	display: flex;
	align-items: center;
	gap: 8px;
}

.nav-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 18px;
	background: #1A1A18;
	color: #F0F4D8 !important;
	border-radius: 99px;
	font-family: 'DM Sans', system-ui, sans-serif;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	white-space: nowrap;
	box-shadow: 0 2px 8px rgba(0,0,0,0.22);
	transition: background 0.18s, transform 0.18s;
}
.nav-pill:hover { background: #2C2C2A; transform: translateY(-1px); text-decoration: none; }

.hamburger-btn {
	width: 34px;
	height: 34px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 5px;
	border-radius: 8px;
	transition: background 0.2s;
	flex-shrink: 0;
}
.hamburger-btn:hover { background: rgba(26,26,24,0.07); }
.bar {
	display: block;
	width: 18px;
	height: 2px;
	background: #1A1A18;
	border-radius: 2px;
	transition: transform 0.32s cubic-bezier(0.4,0,0.2,1), opacity 0.2s;
	transform-origin: center;
}
.hamburger-btn.open .bar:nth-child(1) { transform: translateY(3.25px) rotate(45deg); }
.hamburger-btn.open .bar:nth-child(2) { transform: translateY(-3.25px) rotate(-45deg); }

#nav-links-area {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: max-height 0.42s cubic-bezier(0.4,0,0.2,1), opacity 0.28s ease;
}
#nav-links-area.open { max-height: 420px; opacity: 1; }

.nav-links-inner {
	padding: 8px 20px 0;
	border-top: 1px solid rgba(200,215,140,0.35);
}
.capsule-nav-links {
	list-style: none;
	margin: 0;
	padding: 0;
}
.capsule-nav-links li a {
	display: block;
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: rgba(26,26,24,0.28);
	text-decoration: none;
	padding: 9px 0;
	border-bottom: 1px solid rgba(200,215,140,0.22);
	letter-spacing: -0.02em;
	line-height: 1.15;
	transition: color 0.15s, padding-left 0.2s cubic-bezier(0.34,1.56,0.64,1);
}
.capsule-nav-links li:last-child a { border-bottom: none; }
.capsule-nav-links li a:hover { color: #1A1A18; padding-left: 8px; }

.nav-links-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 20px 18px;
	border-top: 1px solid rgba(200,215,140,0.3);
	margin-top: 4px;
}
.nav-email {
	font-family: 'DM Sans', system-ui, sans-serif;
	font-size: 11px;
	font-weight: 500;
	color: rgba(26,26,24,0.38);
}
.capsule-cta {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 8px 18px;
	background: #F1A035;
	color: #1A1A18 !important;
	border-radius: 99px;
	font-family: 'DM Sans', system-ui, sans-serif;
	font-size: 12px;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.18s;
}
.capsule-cta:hover { background: #e8962d; text-decoration: none; }

/* ==========================================================================
   Homepage — Hero Section
   ========================================================================== */
.home-hero {
	background: var(--c-brand-wash);
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
}
.home-hero__grad-top {
	position: absolute;
	inset-inline: 0;
	top: 0;
	height: 70%;
	background: linear-gradient(180deg, rgba(190,222,30,0.18) 0%, rgba(210,238,60,0.08) 45%, transparent 100%);
	pointer-events: none;
	z-index: 0;
}
.home-hero__grad-bloom {
	position: absolute;
	top: -100px;
	left: 50%;
	transform: translateX(-50%);
	width: 900px;
	height: 500px;
	background: radial-gradient(ellipse at 50% 10%, rgba(200,241,53,0.12) 0%, transparent 65%);
	pointer-events: none;
	z-index: 0;
}
.home-hero__inner {
	position: relative;
	max-width: 768px;
	margin: 0 auto;
	padding: 130px 32px 80px;
	text-align: center;
	z-index: 1;
}
.home-hero__title {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(2.6rem, 4.8vw, 4.4rem);
	font-weight: 700;
	line-height: 1.08;
	letter-spacing: -0.03em;
	color: var(--c-ink);
	margin-bottom: 24px;
}
.home-hero__subtitle {
	font-size: clamp(1rem, 2vw, 1.125rem);
	color: rgba(26,26,24,0.50);
	line-height: 1.65;
	max-width: 560px;
	margin: 0 auto 40px;
}
.home-hero__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 40px;
}
.home-hero__btn--primary {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 28px;
	background: #1A1A18;
	color: #F0F4D8 !important;
	border-radius: 999px;
	font-family: 'DM Sans', system-ui, sans-serif;
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	box-shadow: 0 4px 18px rgba(0,0,0,0.18);
	transition: background 0.2s ease, transform 0.2s ease;
}
.home-hero__btn--primary:hover { background: #2C2C2A; transform: translateY(-1px); text-decoration: none; }
.home-hero__btn--amber {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 28px;
	background: #F1A035;
	color: #1A1A18 !important;
	border-radius: 999px;
	font-family: 'DM Sans', system-ui, sans-serif;
	font-weight: 600;
	font-size: 14px;
	text-decoration: none;
	box-shadow: 0 4px 14px rgba(241,160,53,0.28);
	transition: filter 0.2s ease, transform 0.2s ease;
}
.home-hero__btn--amber:hover { filter: brightness(0.93); transform: translateY(-1px); text-decoration: none; }
.home-hero__trust {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	flex-wrap: wrap;
}
.home-hero__trust-item {
	display: flex;
	align-items: center;
	gap: 6px;
	font-family: 'DM Sans', system-ui, sans-serif;
	font-size: 0.75rem;
	font-weight: 500;
	color: rgba(26,26,24,0.38);
}
.home-hero__trust-item i { font-size: 12px; }
.home-hero__trust-sep {
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: rgba(26,26,24,0.18);
	flex-shrink: 0;
}

/* ==========================================================================
   Homepage — Logo Marquee Section
   ========================================================================== */
.home-logo-marquee {
	background: var(--c-brand-wash);
	border-top: 1px solid var(--c-line);
	padding: 48px 0;
	overflow: hidden;
}
.home-logo-marquee__eyebrow {
	text-align: center;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-ink-muted);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 28px;
}
.logo-track-wrap { overflow: hidden; position: relative; }
.logo-track {
	display: flex;
	gap: 16px;
	width: max-content;
	animation: marquee-scroll 28s linear infinite;
}
.logo-track-wrap:hover .logo-track { animation-play-state: paused; }
.logo-item {
	display: flex;
	align-items: center;
	gap: 12px;
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 14px;
	padding: 14px 22px;
	white-space: nowrap;
	flex-shrink: 0;
	opacity: 0.72;
	box-shadow: 0 1px 6px rgba(0,0,0,0.04);
	transition: opacity 0.22s, box-shadow 0.22s, transform 0.22s;
}
.logo-item:hover {
	opacity: 1;
	box-shadow: 0 6px 24px rgba(0,0,0,0.08);
	transform: translateY(-2px);
}
.logo-icon {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: #1A1A18;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.logo-icon i { font-size: 16px; color: #C8F135; }
.logo-icon--img {
	background: #fff;
	border: 1px solid rgba(26,26,24,0.08);
	overflow: hidden;
	width: auto;
	min-width: 36px;
	max-width: 100px;
	padding: 0 8px;
}
.logo-item__img {
	height: 28px;
	width: auto;
	max-width: 88px;
	object-fit: contain;
	display: block;
}
.logo-name {
	font-family: 'Syne', system-ui, sans-serif;
	font-weight: 700;
	font-size: 15px;
	letter-spacing: -0.02em;
	color: #1A1A18;
	line-height: 1;
}
.logo-tagline {
	font-family: 'DM Sans', system-ui, sans-serif;
	font-size: 11px;
	font-weight: 500;
	color: rgba(26,26,24,0.38);
	margin-top: 2px;
}
@keyframes marquee-scroll {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

/* ==========================================================================
   Homepage — Problem Section
   ========================================================================== */
.home-problem {
	background: var(--c-brand-wash);
	padding: clamp(80px, 10vw, 120px) var(--container-pad);
}
.home-problem__container { max-width: var(--container-max); margin: 0 auto; }
.home-problem__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: #5A7A00;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-align: center;
	margin-bottom: 12px;
}
.home-problem__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 4vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	text-align: center;
	margin: 0 auto 20px;
	max-width: 640px;
}
.home-problem__subtitle {
	font-size: 1.0625rem;
	color: var(--c-ink-60);
	max-width: 560px;
	margin: 0 auto 64px;
	line-height: 1.65;
	text-align: center;
}
.prob-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	margin-bottom: 64px;
}
.prob-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 32px;
	position: relative;
	overflow: hidden;
	box-shadow: 0 1px 10px rgba(0,0,0,0.05);
	transition: transform 0.28s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.28s ease, border-color 0.22s ease;
}
.prob-card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(200,241,53,0.07) 0%, transparent 55%);
	opacity: 0;
	transition: opacity 0.28s ease;
	pointer-events: none;
}
.prob-card:hover {
	transform: translateY(-5px) scale(1.01);
	box-shadow: 0 12px 40px rgba(0,0,0,0.09), 0 0 0 1.5px rgba(200,241,53,0.35);
	border-color: rgba(200,241,53,0.5);
}
.prob-card:hover::after { opacity: 1; }
.prob-icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: #F0F4D8;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
	transition: background 0.22s, transform 0.28s cubic-bezier(0.34,1.56,0.64,1);
}
.prob-card:hover .prob-icon {
	background: #C8F135;
	transform: rotate(-6deg) scale(1.12);
}
.prob-card:hover .prob-icon i { color: #1A1A18 !important; }
/* Services section also uses .prob-card with .prob-card__icon — keep as alias */
.prob-card__icon {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	background: #F0F4D8;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
	font-size: 1.25rem;
	color: #5A7A00;
	transition: background 0.22s, transform 0.28s cubic-bezier(0.34,1.56,0.64,1);
}
.prob-card:hover .prob-card__icon {
	background: #C8F135;
	transform: rotate(-6deg) scale(1.12);
}
.prob-card:hover .prob-card__icon i { color: #1A1A18 !important; }
.prob-card h3 {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--c-ink);
	margin-bottom: 10px;
}
.prob-card p {
	font-size: 0.9375rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	margin: 0;
}
.home-problem__closing {
	text-align: center;
	font-family: 'Syne', sans-serif;
	font-size: clamp(1.125rem, 2vw, 1.375rem);
	font-weight: 700;
	color: var(--c-ink);
	line-height: 1.5;
}
.home-problem__closing .dark-pill {
	display: inline-block;
	background: #1A1A18;
	color: #F0F4D8;
	border-radius: 6px;
	padding: 2px 10px;
	font-weight: 700;
}

/* ==========================================================================
   Homepage — Solution Section
   ========================================================================== */
.home-solution {
	background: var(--c-brand-wash);
	padding: 96px var(--container-pad);
}
.home-solution__container { max-width: var(--container-max); margin: 0 auto; }
.home-solution__header {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-bottom: 64px;
}
@media (min-width: 1024px) {
	.home-solution__header {
		flex-direction: row;
		align-items: flex-end;
		justify-content: space-between;
		gap: 24px;
	}
	.home-solution__header > div:first-child { max-width: 560px; }
	.home-solution__desc { max-width: 320px; margin-bottom: 4px; }
}
.home-solution__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-solution__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin: 0;
}
.home-solution__desc {
	font-size: 1.125rem;
	color: var(--c-ink-muted);
	line-height: 1.65;
	margin: 0;
}
.sol-rows { display: flex; flex-direction: column; }
.sol-row {
	display: grid;
	grid-template-columns: 1fr 1px 1fr;
	gap: 0 40px;
	align-items: center;
	padding: 48px 0;
	border-top: 1px solid #DDE4C0;
}
.sol-row:last-child { border-bottom: 1px solid #DDE4C0; }
.sol-row--output { border-top-color: rgba(200,241,53,0.3); }
.sol-row--output:last-child { border-bottom: 1px solid rgba(200,241,53,0.3); }
.sol-num-col { display: flex; flex-direction: column; }
.sol-num-col--right { align-items: flex-end; }
.sol-divider {
	width: 1px;
	align-self: stretch;
	background: linear-gradient(180deg, transparent, #C8F135 30%, #C8F135 70%, transparent);
}
.sol-num {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 80px;
	font-weight: 800;
	line-height: 1;
	color: rgba(26,26,24,0.06);
	letter-spacing: -0.04em;
}
.sol-tag {
	display: inline-block;
	font-family: 'DM Sans', sans-serif;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--c-green);
	padding: 3px 10px;
	border-radius: 99px;
	background: #EEF3D5;
	border: 1px solid #C8D890;
	margin-bottom: 12px;
}
.sol-tag.output {
	background: #1A1A18;
	border-color: #1A1A18;
	color: #C8F135;
}
.sol-content h3 {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.2;
	color: var(--c-ink);
	margin: 0 0 12px;
}
.sol-body {
	font-size: 0.875rem;
	color: var(--c-ink-muted);
	line-height: 1.65;
	margin: 0 0 16px;
}
.sol-bullets { display: flex; gap: 16px; flex-wrap: wrap; }
.sol-bullet { font-size: 11px; font-weight: 600; color: var(--c-green); }
.sol-metrics { display: flex; gap: 32px; flex-wrap: wrap; }
.sol-metric { text-align: left; }
.sol-metric strong {
	display: block;
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.875rem;
	font-weight: 700;
	color: var(--c-ink);
}
.sol-metric span {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-ink-muted);
}

/* ==========================================================================
   Homepage — Advantage Strip
   ========================================================================== */
.home-advantage {
	background: #EEF3D5;
	border-top: 1px solid #DDE4C0;
	padding: clamp(80px, 8vw, 96px) var(--container-pad);
}
.home-advantage__container { max-width: var(--container-max); margin: 0 auto; }
.home-advantage__header {
	text-align: center;
	margin-bottom: 48px;
}
.home-advantage__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-advantage__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.5rem, 2.5vw, 1.875rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin: 0;
}
.adv-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.adv-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 32px;
	position: relative;
	overflow: hidden;
	box-shadow: 0 1px 10px rgba(0,0,0,0.05);
	transition: transform 0.28s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.28s ease, border-color 0.22s ease;
}
.adv-card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(200,241,53,0.07) 0%, transparent 55%);
	opacity: 0;
	transition: opacity 0.28s ease;
	pointer-events: none;
}
.adv-card:hover {
	transform: translateY(-5px) scale(1.01);
	box-shadow: 0 12px 40px rgba(0,0,0,0.09), 0 0 0 1.5px rgba(200,241,53,0.35);
	border-color: rgba(200,241,53,0.5);
}
.adv-card:hover::after { opacity: 1; }
.adv-card__icon {
	width: 44px;
	height: 44px;
	background: #F0F4D8;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	color: var(--c-green);
	margin-bottom: 20px;
	transition: background 0.22s, transform 0.28s cubic-bezier(0.34,1.56,0.64,1);
}
.adv-card:hover .adv-card__icon {
	background: #C8F135;
	transform: rotate(-6deg) scale(1.12);
}
.adv-card:hover .adv-card__icon i { color: #1A1A18 !important; }
.adv-card h3 {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--c-ink);
	margin-bottom: 8px;
}
.adv-card p {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	margin: 0;
}

/* ==========================================================================
   Homepage — Process Section
   ========================================================================== */
.home-process {
	background: #EEF3D5;
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
}
.home-process__container { max-width: var(--container-max); margin: 0 auto; }
.home-process__header {
	text-align: center;
	margin-bottom: 64px;
}
.home-process__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-process__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin: 0 0 20px;
}
.home-process__subheading {
	font-size: 1.125rem;
	color: var(--c-ink-soft);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.6;
}
/* Timeline */
.proc-timeline {
	position: relative;
	max-width: 680px;
	margin: 0 auto;
	padding-left: 0;
}
.proc-timeline::before {
	content: '';
	position: absolute;
	left: 19px;
	top: 20px;
	bottom: 20px;
	width: 2px;
	background: linear-gradient(180deg, #C8F135 0%, #C8F135 75%, rgba(200,241,53,0.1) 100%);
}
.proc-item {
	display: flex;
	gap: 28px;
	align-items: flex-start;
	position: relative;
}
.proc-item:last-child { margin-bottom: 0; }
.proc-dot {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #fff;
	border: 2px solid #C8F135;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	z-index: 1;
	box-shadow: 0 0 0 4px #EEF3D5;
}
.proc-dot.active {
	background: #C8F135;
	border-color: #C8F135;
}
.proc-dot i { font-size: 16px; color: #1A1A18; }
.proc-body {
	flex: 1;
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 24px 28px;
	margin-bottom: 16px;
	box-shadow: 0 1px 6px rgba(0,0,0,0.04);
	transition: box-shadow 0.22s, transform 0.22s;
}
.proc-body:hover { box-shadow: 0 8px 28px rgba(0,0,0,0.08); transform: translateY(-2px); }
.proc-step {
	font-family: 'DM Sans', sans-serif;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: #5A7A00;
	margin-bottom: 8px;
}
.proc-item h3 {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--c-ink);
	margin-bottom: 8px;
	line-height: 1.2;
}
.proc-item p {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	margin: 0;
}
/* Step stats footer */
.proc-stats {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	margin-top: 16px;
	padding-top: 12px;
	border-top: 1px solid #DDE4C0;
}
.proc-stat {
	font-size: 0.75rem;
	font-weight: 600;
	color: #5A7A00;
}
/* Step 4 — dark card */
.proc-body--final {
	background: #1A1A18;
	border-color: rgba(200,241,53,0.25);
	box-shadow: 0 2px 20px rgba(200,241,53,0.08);
}
.proc-body--final:hover { box-shadow: 0 8px 28px rgba(200,241,53,0.12); transform: translateY(-2px); }
.proc-body--final .proc-step { color: rgba(200,241,53,0.6); }
.proc-body--final h3 { color: #F0F4D8; }
.proc-body--final p  { color: rgba(240,244,216,0.55); }
.proc-body--final .proc-stats { border-top-color: rgba(240,244,216,0.10); }
/* Step 4 metrics */
.proc-metrics {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
	margin-top: 16px;
	padding-top: 12px;
	border-top: 1px solid rgba(240,244,216,0.10);
}
.proc-metric strong {
	display: block;
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	color: #C8F135;
}
.proc-metric span {
	font-size: 0.75rem;
	font-weight: 600;
	color: rgba(240,244,216,0.4);
}

/* ==========================================================================
   Homepage — Results Section
   ========================================================================== */
.home-results {
	background: #EEF3D5;
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
}
.home-results__container { max-width: 1280px; margin: 0 auto; }
.home-results__header {
	text-align: center;
	margin-bottom: 80px;
}
.home-results__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-results__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin-bottom: 16px;
}
.home-results__subtitle {
	font-size: 1.125rem;
	color: var(--c-ink-muted);
	line-height: 1.65;
	margin: 0;
}
/* Metric cards */
.metrics-row {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-bottom: 80px;
}
.metric-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 32px;
	text-align: center;
}
.metric-value {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 3.5rem;
	font-weight: 700;
	line-height: 1;
	color: var(--c-ink);
	margin-bottom: 4px;
}
.metric-unit {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #5A7A00;
	margin-bottom: 8px;
}
.metric-label {
	font-size: 0.875rem;
	color: rgba(26,26,24,0.45);
}
.metric-bar-section {
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid #DDE4C0;
}
.metric-bar {
	height: 6px;
	background: #EEF3D5;
	border-radius: 999px;
	overflow: hidden;
}
.metric-bar-fill {
	height: 100%;
	background: #C8F135;
	border-radius: 999px;
}
/* Testimonial cards */
.results-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.result-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 32px;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.25s, transform 0.25s;
}
.result-card:hover {
	box-shadow: 0 12px 48px rgba(44,20,76,0.12);
	transform: translateY(-4px);
}
.result-card__header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 24px;
}
.result-avatar {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	font-weight: 700;
	font-family: 'Syne', system-ui, sans-serif;
	flex-shrink: 0;
}
.result-card__meta strong {
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	color: var(--c-ink);
}
.result-card__meta span {
	font-size: 0.75rem;
	color: var(--c-ink-muted);
}
.result-stars {
	color: #F5A623;
	font-size: 13px;
	letter-spacing: 2px;
	margin-bottom: 16px;
}
.result-card blockquote {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	margin: 0 0 24px;
	flex: 1;
}
.result-card__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding-top: 16px;
	border-top: 1px solid #DDE4C0;
}
.context-tag {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: #F0F4D8;
	border: 1px solid #DDE4C0;
	border-radius: 99px;
	padding: 3px 10px;
	font-size: 11px;
	font-weight: 600;
	color: #5A7A00;
}

/* ==========================================================================
   Homepage — Services Section
   ========================================================================== */
.home-services {
	background: var(--c-brand-wash);
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
}
.home-services__container { max-width: 1280px; margin: 0 auto; }
.home-services__header {
	text-align: center;
	margin-bottom: 64px;
}
.home-services__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-services__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin-bottom: 24px;
}
.home-services__subtitle {
	font-size: 1.125rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	max-width: 672px;
	margin: 0 auto;
}
.services-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}
.home-services__addons {
	text-align: center;
	margin-top: 64px;
	padding-top: 48px;
	border-top: 1px solid #DDE4C0;
}
.addons-label {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: rgba(26,26,24,0.35);
	margin-bottom: 20px;
}
.addons-row {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	justify-content: center;
}
.addon-pill {
	display: inline-block;
	padding: 10px 20px;
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 999px;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-ink-muted);
	box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}

/* ==========================================================================
   Homepage — Who We Work With
   ========================================================================== */
.home-who {
	background: #F5F8E8;
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
}
.home-who__container { max-width: 1280px; margin: 0 auto; }
.home-who__header { text-align: center; margin-bottom: 64px; }
.home-who__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-who__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin-bottom: 16px;
}
.home-who__subtitle {
	font-size: 1.125rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	max-width: 672px;
	margin: 0 auto;
}
.who-cols {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
}
.who-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 40px;
}
.who-card__header {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 32px;
}
.who-card__icon {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.who-card__icon--good { background: #C8F135; }
.who-card__icon--bad  { background: rgba(192,57,43,0.10); }
.who-card h3 {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--c-ink);
	margin: 0;
}
.who-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.who-list li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}
.who-list li span:last-child {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
}
.who-dot {
	width: 5px;
	height: 5px;
	border-radius: 50%;
	flex-shrink: 0;
	margin-top: 8px;
	display: inline-block;
}
.who-dot--good { background: #8AAB00; }
.who-dot--bad  { background: rgba(192,57,43,0.40); }

/* ==========================================================================
   Homepage — Founder Section
   ========================================================================== */
.home-founder {
	background: #F5F8E8;
	border-top: 1px solid #DDE4C0;
	border-bottom: 1px solid #DDE4C0;
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
}
.home-founder__container {
	max-width: 1152px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: center;
}
.home-founder__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 24px;
}
.founder-identity {
	display: flex;
	align-items: center;
	gap: 20px;
	margin-bottom: 40px;
}
.founder-avatar {
	width: 64px;
	height: 64px;
	border-radius: 16px;
	background: var(--c-ink);
	color: var(--c-lime);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.25rem;
	font-weight: 700;
	font-family: 'Syne', system-ui, sans-serif;
	flex-shrink: 0;
}
.founder-name {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--c-ink);
	margin: 0 0 2px;
}
.founder-title {
	font-size: 0.875rem;
	color: var(--c-ink-muted);
	margin: 0;
}
.founder-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	margin-bottom: 24px;
}
.founder-stat {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 12px;
	padding: 20px;
}
.founder-stat strong {
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	font-family: 'Syne', system-ui, sans-serif;
	color: var(--c-amber);
	margin-bottom: 4px;
}
.founder-stat span {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-ink-muted);
}
.founder-email { margin-top: 24px; }
.founder-email a {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--c-green);
	text-decoration: none;
}
.founder-email a:hover { text-decoration: underline; }
.founder-quote-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 40px;
}
.quote-icon {
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: #C8F135;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
}
.founder-quote-body {
	display: flex;
	flex-direction: column;
	gap: 16px;
	margin-bottom: 32px;
}
.founder-quote-body p {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	margin: 0;
}
.founder-sig-block {
	padding-top: 24px;
	border-top: 1px solid #DDE4C0;
}
.founder-sig-name {
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 1.75rem;
	font-style: italic;
	color: var(--c-ink);
	margin: 0 0 2px;
	letter-spacing: 0.01em;
}
.founder-sig-label {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-ink-muted);
	margin: 0;
}

/* ==========================================================================
   Homepage — Getting Started Section
   ========================================================================== */
.home-getting-started {
	background: #EEF3D5;
	border-top: 1px solid #DDE4C0;
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
}
.home-getting-started__container { max-width: 1280px; margin: 0 auto; }
.home-getting-started__header { text-align: center; margin-bottom: 64px; }
.home-getting-started__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-getting-started__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin: 0;
}
.steps-cols {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.step-card {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: 32px;
	display: flex;
	flex-direction: column;
}
.step-card__header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 24px;
}
.step-num {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.875rem;
	font-weight: 700;
	font-family: 'Syne', system-ui, sans-serif;
	flex-shrink: 0;
}
.step-num.lime { background: #C8F135; color: #1A1A18; }
.step-num.dark { background: #1A1A18; color: #C8F135; }
.step-card h3 {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--c-ink);
	margin: 0;
}
.step-card > p {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	margin: 0 0 20px;
	flex: 1;
}
.step-card__footer {
	padding-top: 16px;
	border-top: 1px solid #DDE4C0;
	margin-top: auto;
}
.step-footer-tag {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
}

/* ==========================================================================
   Homepage — FAQ Section
   ========================================================================== */
.home-faq {
	background: #EEF3D5;
	border-top: 1px solid #DDE4C0;
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
}
.home-faq__container { max-width: 896px; margin: 0 auto; }
.home-faq__header { text-align: center; margin-bottom: 64px; }
.home-faq__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.home-faq__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin: 0;
}
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-item {
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	overflow: hidden;
}
.faq-toggle {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 24px;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: 'Syne', system-ui, sans-serif;
	font-size: 1rem;
	font-weight: 700;
	color: var(--c-ink);
}
.faq-toggle span { flex: 1; }
.faq-toggle i {
	font-size: 16px;
	color: var(--c-green);
	flex-shrink: 0;
	transition: transform 0.3s ease;
}
.faq-toggle.open i { transform: rotate(180deg); }
.accordion-content {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: max-height 0.35s ease-in-out, opacity 0.3s ease-in-out;
}
.accordion-content.open {
	max-height: 400px;
	opacity: 1;
}
.accordion-content__inner {
	background: #F5F8E8;
	padding: 0 24px 24px;
}
.accordion-content__inner p {
	font-size: 0.875rem;
	color: var(--c-ink-soft);
	line-height: 1.65;
	margin: 0;
}

/* ==========================================================================
   Homepage — Final CTA Section
   ========================================================================== */
.home-cta {
	background: var(--c-brand-wash);
	border-top: 1px solid var(--c-line);
	padding: clamp(96px, 10vw, 128px) var(--container-pad);
	text-align: center;
}
.home-cta__container { max-width: 768px; margin: 0 auto; position: relative; z-index: 1; }
.home-cta__eyebrow {
	display: block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--c-green);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 24px;
}
.home-cta__heading {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.875rem, 3.5vw, 3rem);
	font-weight: 700;
	letter-spacing: -0.025em;
	line-height: 1.15;
	color: var(--c-ink);
	margin-bottom: 20px;
}
.home-cta__subtitle {
	font-size: 1.125rem;
	color: rgba(26,26,24,0.52);
	line-height: 1.65;
	max-width: 560px;
	margin: 0 auto 40px;
}
.home-cta__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 24px;
}
.home-cta__fine {
	font-size: 0.75rem;
	font-weight: 500;
	color: rgba(26,26,24,0.30);
}

/* ==========================================================================
   Homepage — Dark Footer
   ========================================================================== */
.site-footer-coldicp {
	background: var(--c-ink);
	color: rgba(255,255,255,0.85);
}
.footer-cta-strip {
	border-bottom: 1px solid rgba(255,255,255,0.08);
	padding: 48px var(--container-pad);
}
.footer-cta-strip__inner {
	max-width: 1152px;
	margin: 0 auto;
	padding: 0 var(--container-pad);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
}
.footer-cta-strip h2 {
	font-family: 'Syne', system-ui, sans-serif;
	font-size: clamp(1.375rem, 2.5vw, 1.875rem);
	font-weight: 700;
	color: #F0F4D8;
	letter-spacing: -0.02em;
	line-height: 1.15;
	margin: 0 0 8px;
}
.footer-cta-strip__sub {
	font-size: 0.875rem;
	color: rgba(240,244,216,0.40);
	margin: 0;
}
.footer-cta-strip__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.footer-btn-lime {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 24px;
	background: var(--c-lime);
	color: var(--c-ink) !important;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.9375rem;
	text-decoration: none;
	transition: filter 0.2s ease;
}
.footer-btn-lime:hover { filter: brightness(0.93); text-decoration: none; }
.footer-btn-amber {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 12px 24px;
	background: #F1A035;
	border: none;
	color: #1A1A18 !important;
	border-radius: 999px;
	font-weight: 700;
	font-size: 0.875rem;
	text-decoration: none;
	box-shadow: 0 4px 14px rgba(241,160,53,0.22);
	transition: filter 0.2s ease, transform 0.2s ease;
}
.footer-btn-amber:hover { filter: brightness(0.93); transform: translateY(-1px); text-decoration: none; }
.footer-main {
	max-width: 1152px;
	margin: 0 auto;
	padding: 56px var(--container-pad) 0;
}
.footer-grid {
	max-width: 1152px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 48px;
}
.footer-brand-col {}
.footer-logo {
	display: flex;
	align-items: center;
	gap: 10px;
	font-family: 'Syne', system-ui, sans-serif;
	font-weight: 700;
	font-size: 1.125rem;
	color: #fff;
	text-decoration: none;
	margin-bottom: 14px;
}
.footer-logo:hover { color: #fff; text-decoration: none; }
.footer-logo-icon {
	width: 30px;
	height: 30px;
	background: #F0F4D8;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.8125rem;
	color: #1A1A18;
	flex-shrink: 0;
	overflow: hidden;
}
.footer-logo-img__img {
	width: 20px;
	height: 20px;
	object-fit: contain;
	display: block;
}
.footer-tagline {
	font-size: 0.875rem;
	color: rgba(240,244,216,0.38);
	line-height: 1.6;
	max-width: 220px;
	margin-bottom: 24px;
}
.footer-email a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.75rem;
	font-weight: 600;
	color: rgba(200,241,53,0.70);
	text-decoration: none;
}
.footer-email a:hover { color: var(--c-lime); }
.footer-col h4 {
	font-size: 0.75rem;
	font-weight: 600;
	color: rgba(240,244,216,0.25);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-family: 'DM Sans', sans-serif;
	margin-bottom: 20px;
}
.footer-col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.footer-col ul li a {
	font-size: 0.875rem;
	color: rgba(240,244,216,0.45);
	text-decoration: none;
	transition: color 0.15s ease;
}
.footer-col ul li a:hover { color: rgba(240,244,216,0.85); }
.footer-bottom-bar {
	border-top: 1px solid rgba(240,244,216,0.06);
	padding: 20px var(--container-pad);
	margin-top: 48px;
}
.footer-bottom {
	max-width: 1152px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	flex-wrap: wrap;
}
.footer-copyright {
	font-size: 0.75rem;
	color: rgba(240,244,216,0.18);
}
.footer-legal {
	display: flex;
	gap: 24px;
}
.footer-legal a {
	font-size: 0.75rem;
	color: rgba(240,244,216,0.18);
	text-decoration: none;
}
.footer-legal a:hover { color: rgba(240,244,216,0.55); }

/* wp_nav_menu() inside .footer-legal — flatten ul/li into inline flex row */
.footer-legal ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 24px;
}
.footer-legal ul li { margin: 0; padding: 0; }

/* ==========================================================================
   Homepage — Scroll Fade Animations
   ========================================================================== */
.fade-in-section {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in-section.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* ==========================================================================
   Homepage — Responsive Breakpoints
   ========================================================================== */

/* ── Process timeline (768px) ─────────────────────────────────────────────── */
@media (max-width: 768px) {
	.proc-timeline { padding: 0 2px; }
	.proc-timeline::before { left: 16px; top: 16px; bottom: 16px; }
	.proc-dot { width: 34px; height: 34px; box-shadow: 0 0 0 3px #EEF3D5; }
	.proc-dot i { font-size: 13px; }
	.proc-item { gap: 14px; }
	.proc-body { padding: 16px 14px; margin-bottom: 10px; }
	.proc-stats { flex-wrap: wrap; gap: 8px; }
	.proc-metrics { flex-wrap: wrap; gap: 12px; }
}

/* ── Tablet / medium (900px) ─────────────────────────────────────────────── */
@media (max-width: 900px) {
	#navbar { width: 90%; }

	/* Solution */
	.sol-row { grid-template-columns: 1fr; gap: 0; padding: 28px 0; }
	.sol-divider { display: none; }
	.sol-num { font-size: 48px; }

	/* Homepage grids → single column */
	.adv-cards { grid-template-columns: 1fr; gap: 16px; }
	.metrics-row { grid-template-columns: 1fr; gap: 12px; margin-bottom: 48px; }
	.results-grid { grid-template-columns: 1fr; gap: 16px; }
	.services-grid { grid-template-columns: 1fr; gap: 20px; }
	.home-founder__container { grid-template-columns: 1fr; gap: 40px; }
	.who-cols { grid-template-columns: 1fr; }
	.steps-cols { grid-template-columns: 1fr; }

	/* Footer grid → 2 columns */
	.footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }

	/* Footer CTA strip → stack vertically */
	.footer-cta-strip { padding: 40px 0; }
	.footer-cta-strip__inner { flex-direction: column; align-items: flex-start; gap: 24px; }
}

/* ── Tablet mid-range 2-column cards ────────────────────────────────────── */
@media (min-width: 640px) and (max-width: 900px) {
	.adv-cards { grid-template-columns: repeat(2, 1fr); }
	.metrics-row { grid-template-columns: repeat(3, 1fr); }
	.results-grid { grid-template-columns: repeat(2, 1fr); }
	.services-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
	.steps-cols { grid-template-columns: repeat(2, 1fr); }
}

/* ── Mobile (640px) ──────────────────────────────────────────────────────── */
@media (max-width: 640px) {
	#navbar { width: 94%; top: 12px; }
	.nav-pill { display: none; }

	/* Hero */
	.home-hero__trust { flex-direction: column; gap: 12px; }
	.home-hero__actions { flex-direction: column; align-items: center; width: 100%; }
	.home-hero__btn--primary,
	.home-hero__btn--amber { width: 100%; justify-content: center; }

	/* Final CTA section */
	.home-cta__actions { flex-direction: column; align-items: center; }

	/* Who section */
	.home-who { padding-left: 16px; padding-right: 16px; }

	/* Founder stats → single column on very small screens */
	.founder-stats { grid-template-columns: 1fr 1fr 1fr; }

	/* Footer grid → single column */
	.footer-grid { grid-template-columns: 1fr; gap: 40px; }

	/* Footer brand col — release tagline max-width */
	.footer-tagline { max-width: 100%; }

	/* Footer CTA strip — full-width buttons */
	.footer-cta-strip { padding: 32px 0; }
	.footer-cta-strip__inner { gap: 20px; }
	.footer-cta-strip__actions { flex-direction: column; width: 100%; }
	.footer-btn-lime,
	.footer-btn-amber { width: 100%; justify-content: center; }

	/* Footer bottom bar */
	.footer-bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
	.footer-bottom-bar { padding: 20px 16px; }

	/* Footer main */
	.footer-main { padding-left: 16px; padding-right: 16px; }
}

/* ==========================================================================
   Book A Meeting Page — Brand redesign
   ========================================================================== */

/* ── Shared eyebrow ────────────────────────────────────────────────────────── */
.bm-eyebrow {
	display: inline-block;
	font-family: 'DM Sans', system-ui;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(26,26,24,0.50);
	margin-bottom: 14px;
}

.bm-eyebrow--small {
	font-size: 0.7rem;
}

.bm-eyebrow--lime {
	color: #C8F135;
}

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.bm-hero {
	background: var(--c-brand-wash);
	background-image: linear-gradient(160deg, rgba(200,241,53,0.25) 0%, transparent 60%);
	padding: clamp(100px, 14vw, 160px) 0 clamp(60px, 8vw, 96px);
	text-align: center;
	position: relative;
	overflow: hidden;
}

.bm-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
}

.bm-hero__title {
	font-family: 'Syne', system-ui;
	font-size: clamp(2.25rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--c-ink);
	line-height: 1.1;
	letter-spacing: -0.04em;
	margin: 0 0 20px;
}

.bm-hero__subtitle {
	font-size: clamp(1rem, 2vw, 1.125rem);
	color: rgba(26,26,24,0.65);
	max-width: 540px;
	margin: 0 auto 40px;
	line-height: 1.65;
}

/* Trust chips */
.bm-hero__chips {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	flex-wrap: wrap;
}

.bm-hero__chip {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255,255,255,0.80);
	border: 1px solid rgba(200,215,140,0.60);
	border-radius: 999px;
	padding: 8px 16px;
	backdrop-filter: blur(4px);
}

.bm-hero__chip-number {
	font-family: 'Syne', system-ui;
	font-size: 0.875rem;
	font-weight: 700;
	color: #1A1A18;
	letter-spacing: -0.02em;
}

.bm-hero__chip-label {
	font-family: 'DM Sans', system-ui;
	font-size: 0.75rem;
	font-weight: 500;
	color: rgba(26,26,24,0.60);
}

/* ── Single-column body ───────────────────────────────────────────────────── */
.bm-body {
	background: #fff;
	padding: clamp(56px, 8vw, 96px) 0;
	border-top: 1px solid #DDE4C0;
	border-bottom: 1px solid #DDE4C0;
}

.bm-body__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(48px, 6vw, 72px);
	max-width: 900px;
	margin: 0 auto;
}

/* ── How It Works block ───────────────────────────────────────────────────── */
.bm-steps-block {
	text-align: center;
}

.bm-steps-block__heading {
	font-family: 'Syne', system-ui;
	font-size: clamp(1.375rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: #1A1A18;
	letter-spacing: -0.03em;
	margin: 0 0 32px;
	line-height: 1.2;
}

/* Horizontal card grid */
.bm-steps-grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 20px;
	text-align: left;
}

.bm-step-card {
	background: var(--c-brand-wash);
	border: 1px solid #DDE4C0;
	border-top: 3px solid #C8F135;
	border-radius: 14px;
	padding: clamp(22px, 3vw, 30px);
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.bm-step-card:hover {
	box-shadow: 0 8px 24px rgba(0,0,0,0.06);
	transform: translateY(-2px);
}

.bm-step-card__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	border-radius: 8px;
	background: #C8F135;
	color: #1A1A18;
	font-family: 'Syne', system-ui;
	font-size: 0.75rem;
	font-weight: 800;
	letter-spacing: 0.02em;
	flex-shrink: 0;
}

.bm-step-card__title {
	font-family: 'Syne', system-ui;
	font-size: 0.9375rem;
	font-weight: 700;
	color: #1A1A18;
	line-height: 1.3;
	margin: 0;
}

.bm-step-card__desc {
	font-size: 0.875rem;
	color: rgba(26,26,24,0.60);
	line-height: 1.65;
	margin: 0;
}

/* ── Calendar (full-width) ────────────────────────────────────────────────── */
.bm-calendar {
	width: 100%;
}

/* ── Tabs ─────────────────────────────────────────────────────────────────── */
.bm-tabs {
	display: flex;
	gap: 6px;
	background: var(--c-brand-wash);
	border: 1px solid #DDE4C0;
	border-radius: 12px;
	padding: 5px;
	margin-bottom: 20px;
	width: fit-content;
}

/* Keep old .book-meeting-tabs functional for JS targeting */
.book-meeting-tabs {
	display: flex;
	gap: 6px;
	background: var(--c-brand-wash);
	border: 1px solid #DDE4C0;
	border-radius: 12px;
	padding: 5px;
	margin-bottom: 20px;
	width: fit-content;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.book-meeting-tabs::-webkit-scrollbar { display: none; }

.bm-tab,
.book-meeting-tab {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1px;
	background: transparent;
	border: none;
	border-radius: 8px;
	padding: 9px 20px;
	font-family: 'DM Sans', system-ui;
	font-size: 0.875rem;
	font-weight: 600;
	color: rgba(26,26,24,0.55);
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease;
	white-space: nowrap;
}

.bm-tab:hover,
.book-meeting-tab:hover {
	color: #1A1A18;
}

.bm-tab.is-active,
.book-meeting-tab.is-active {
	background: #1A1A18;
	color: #C8F135;
}

.bm-tab__label,
.book-meeting-tab__label { display: block; }

.bm-tab__desc,
.book-meeting-tab__desc {
	display: block;
	font-size: 0.6875rem;
	font-weight: 400;
	color: currentColor;
	opacity: 0.70;
}

/* ── Cal.com embed containers ────────────────────────────────────────────── */
.book-meeting-cal-panel[hidden],
.bm-cal-panel[hidden] { display: none; }

.book-meeting-cal-embed,
.bm-cal-embed {
	width: 100%;
	height: clamp(600px, 80vh, 900px);
	overflow: hidden;
	border-radius: 16px;
	border: 1px solid #DDE4C0;
}

.bm-cal-placeholder {
	padding: 64px 32px;
	text-align: center;
	border: 2px dashed #DDE4C0;
	border-radius: 16px;
	color: rgba(26,26,24,0.45);
}

.bm-cal-placeholder i {
	font-size: 2.5rem;
	color: #DDE4C0;
	display: block;
	margin-bottom: 12px;
}

/* ── Before We Connect (washed lime-wash bg — distinct from dark footer) ──── */
.bm-info {
	background: #EEF3D0;
	padding: clamp(64px, 9vw, 100px) 0;
}

.bm-info__header {
	text-align: center;
	max-width: 560px;
	margin: 0 auto clamp(40px, 5vw, 60px);
}

.bm-info__heading {
	font-family: 'Syne', system-ui;
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	color: #1A1A18;
	letter-spacing: -0.04em;
	line-height: 1.1;
	margin: 0 0 14px;
}

.bm-info__intro {
	font-size: 1rem;
	color: rgba(26,26,24,0.60);
	line-height: 1.65;
	margin: 0;
}

.bm-info__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(16px, 2.5vw, 24px);
}

.bm-info-card {
	background: rgba(255,255,255,0.75);
	border: 1px solid #DDE4C0;
	border-radius: 16px;
	padding: clamp(24px, 3vw, 32px);
	display: flex;
	flex-direction: column;
	gap: 14px;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.bm-info-card:hover {
	box-shadow: 0 8px 24px rgba(0,0,0,0.06);
	transform: translateY(-2px);
}

.bm-info-card__icon {
	width: 44px;
	height: 44px;
	border-radius: 10px;
	background: #1A1A18;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #C8F135;
	font-size: 1.25rem;
	flex-shrink: 0;
}

.bm-info-card__title {
	font-family: 'Syne', system-ui;
	font-size: 1.0625rem;
	font-weight: 700;
	color: #1A1A18;
	margin: 0;
	line-height: 1.25;
}

.bm-info-card__desc {
	font-size: 0.875rem;
	color: rgba(26,26,24,0.65);
	line-height: 1.7;
	margin: 0;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
	.bm-steps-grid {
		grid-template-columns: 1fr;
	}

	.bm-info__grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}

	.bm-info-card {
		flex-direction: row;
		align-items: flex-start;
		gap: 16px;
	}

	.bm-info-card__icon {
		flex-shrink: 0;
	}
}

@media (max-width: 640px) {
	.bm-hero__chips { gap: 8px; }

	.bm-tabs,
	.book-meeting-tabs {
		width: 100%;
	}

	.bm-tab,
	.book-meeting-tab {
		flex: 1;
		padding: 8px 12px;
		font-size: 0.8125rem;
	}

	.book-meeting-cal-embed,
	.bm-cal-embed {
		border-radius: 10px;
	}
}

/* Legacy classes — kept so old JS selectors still work */
.book-meeting-page { position: relative; }

/* ==========================================================================
   Capsule Navbar — Mobile Responsive
   ========================================================================== */
@media (max-width: 768px) {
	#navbar { padding: 10px 0 0; }
	.nav-capsule { width: calc(100% - 32px); }
	.nav-pill { font-size: 12px; padding: 7px 14px; }
	.capsule-nav-links li a { font-size: 18px; padding: 8px 0; }
	.nav-links-inner { padding: 6px 16px 0; }
	.nav-links-footer { padding: 12px 16px 16px; }
	.capsule-cta { font-size: 11px; padding: 7px 14px; }
	.capsule-topbar { padding: 8px 8px 8px 14px; }
}

/* ==========================================================================
   Hero — Mobile Responsive
   ========================================================================== */
@media (max-width: 640px) {
	.home-hero__inner { padding: 100px 20px 60px; }
	.home-hero__title { font-size: clamp(2rem, 8vw, 2.8rem); }
	.home-hero__grad-bloom { width: 100%; }
}

/* ==========================================================================
   Problem Section — Responsive
   ========================================================================== */
@media (max-width: 1024px) {
	.prob-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
}
@media (max-width: 640px) {
	.prob-grid { grid-template-columns: 1fr; gap: 16px; }
	.prob-card { padding: 24px 20px; }
}

/* ── Dark mode overrides ─────────────────────────────────────────────────── */

/* ==========================================================================
   Featured Post Card — full-width hero card on blog index
   ========================================================================== */
.featured-post {
	margin-bottom: 48px;
}

.featured-post__card {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	background: #fff;
	border: 1px solid #DDE4C0;
	border-radius: 32px;
	padding: 32px;
	align-items: center;
	transition: all 0.3s ease;
	text-decoration: none;
	color: inherit;
}

.featured-post__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 40px rgba(0,0,0,0.08);
	border-color: #C8F135;
}

.featured-post__image-wrap {
	width: 100%;
	aspect-ratio: 16/9;
	background: #F5F8E8;
	border-radius: 16px;
	overflow: hidden;
}

.featured-post__image-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 6rem;
	color: rgba(26,26,24,0.10);
}

.featured-post__image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	display: block;
}

.featured-post__card:hover .featured-post__image-wrap img {
	transform: scale(1.04);
}

.featured-post__body {
	flex: 1;
	padding-right: 16px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.featured-post__badges {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 16px;
	flex-wrap: wrap;
}

.featured-post__badge {
	display: inline-block;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #C8F135;
	background: #1A1A18;
	border-radius: 999px;
	padding: 6px 12px;
}

.featured-post__read-time {
	font-size: 13px;
	color: #6A6A68;
}

.featured-post__title {
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.15;
	color: #1A1A18;
	margin-bottom: 24px;
	font-family: 'Syne', system-ui;
}

.featured-post__excerpt {
	font-size: 1.125rem;
	color: #3A3A38;
	line-height: 1.7;
	margin-bottom: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

@media (max-width: 1024px) {
	.featured-post__card {
		grid-template-columns: 1fr;
		gap: 24px;
		padding: 24px;
	}
	.featured-post__body {
		padding-right: 0;
	}
	.featured-post__image-wrap {
		aspect-ratio: 16/9;
	}
}

/* ==========================================================================
   Post Inner CTA — dark section after article content
   ========================================================================== */
.post-inner-cta-wrapper {
	background: #F0F4D8;
	padding: clamp(48px, 6vw, 80px) clamp(16px, 5vw, 48px);
	display: block;
	clear: both;
}

.post-inner-cta {
	background: #1A1A18;
	border-radius: 24px;
	max-width: 900px;
	margin: 0 auto;
	padding: clamp(40px, 8vw, 64px) clamp(24px, 6vw, 56px);
	text-align: center;
}

/* Pagination */
.pagination-wrapper {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 80px;
}

/* paginate_links with type:'list' outputs a <ul> */
.pagination-wrapper ul {
	display: flex;
	align-items: center;
	gap: 8px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.pagination-wrapper ul li {
	display: flex;
}

.pagination-wrapper .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid #DDE4C0;
	border-radius: 999px;
	font-family: 'DM Sans', system-ui;
	font-size: 0.875rem;
	font-weight: 700;
	text-decoration: none;
	color: #1A1A18;
	background: transparent;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
	line-height: 1;
}

.pagination-wrapper .page-numbers:hover,
.pagination-wrapper .page-numbers:focus {
	background: #1A1A18;
	color: #C8F135;
	border-color: #1A1A18;
}

.pagination-wrapper .page-numbers.current {
	background: #1A1A18;
	color: #C8F135;
	border-color: #1A1A18;
}

.pagination-wrapper .page-numbers.dots {
	width: auto;
	padding: 0 4px;
	border-color: transparent;
	background: transparent;
	color: #6A6A68;
	pointer-events: none;
}

/* Prev / next icons */
.pagination-wrapper .page-numbers.prev,
.pagination-wrapper .page-numbers.next {
	font-size: 1rem;
}

.post-inner-cta__heading {
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.03em;
	line-height: 1.12;
	margin: 0 0 16px;
	font-family: 'Syne', system-ui;
}

.post-inner-cta__subtitle {
	font-size: 1rem;
	color: rgba(255,255,255,0.60);
	max-width: 480px;
	margin: 0 auto 32px;
	line-height: 1.65;
}

.post-inner-cta__actions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	flex-wrap: wrap;
}

.post-inner-cta__btn--primary {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 14px 28px;
	background: #C8F135;
	color: var(--c-ink);
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 700;
	text-decoration: none;
	transition: transform 0.2s ease, background 0.2s ease;
}

.post-inner-cta__btn--primary:hover {
	transform: scale(1.04);
	background: #D4F55A;
}

.post-inner-cta__btn--ghost {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 14px 28px;
	background: rgba(255,255,255,0.10);
	color: #fff;
	border: 1px solid rgba(255,255,255,0.20);
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 700;
	text-decoration: none;
	transition: background 0.2s ease;
}

.post-inner-cta__btn--ghost:hover {
	background: rgba(255,255,255,0.16);
	color: #fff;
}



/* ==========================================================================
   Page Hero — Static Page Header (page.html)
   ========================================================================== */
.page-hero {
	background: var(--c-brand-wash);
	background-image: linear-gradient(180deg, rgba(200,241,53,0.18) 0%, transparent 100%);
	padding: clamp(80px, 12vw, 140px) var(--container-pad) clamp(48px, 8vw, 80px);
	text-align: center;
}

.page-hero__inner {
	max-width: 720px;
	margin: 0 auto;
}

.page-hero .breadcrumbs {
	margin-bottom: 20px;
	justify-content: center;
}

.page-hero__eyebrow {
	font-family: 'DM Sans', system-ui;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(26,26,24,0.50);
	margin-bottom: 16px;
}

.page-hero__title {
	font-family: 'Syne', system-ui;
	font-size: clamp(2.25rem, 5vw, 3.5rem);
	font-weight: 700;
	color: var(--c-ink);
	letter-spacing: -0.04em;
	line-height: 1.1;
	margin: 0;
}

/* ==========================================================================
   Search Hero & Search Results Page
   ========================================================================== */
.search-results-page {
	background: var(--c-brand-wash);
}

.search-hero {
	background: var(--c-brand-wash);
	background-image: linear-gradient(180deg, rgba(200,241,53,0.18) 0%, transparent 100%);
	padding: clamp(80px, 12vw, 140px) var(--container-pad) clamp(48px, 8vw, 80px);
	text-align: center;
	border-bottom: 1px solid rgba(200,215,140,0.40);
}

.search-hero__inner {
	max-width: 640px;
	margin: 0 auto;
}

.search-hero__eyebrow {
	font-family: 'DM Sans', system-ui;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(26,26,24,0.50);
	margin-bottom: 16px;
}

.search-hero__title {
	font-family: 'Syne', system-ui;
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 700;
	color: var(--c-ink);
	letter-spacing: -0.04em;
	line-height: 1.1;
	margin: 0 0 12px;
}

.search-hero__count {
	font-size: 0.9375rem;
	color: rgba(26,26,24,0.55);
	margin: 0 0 32px;
}

.search-hero__form {
	max-width: 480px;
	margin: 0 auto;
}

/* Search results grid */
.search-results-body {
	max-width: 1200px;
	margin: 0 auto;
	padding: clamp(48px, 8vw, 80px) var(--container-pad) clamp(48px, 8vw, 96px);
}

/* No results state */
.search-no-results {
	text-align: center;
	padding: 64px 0;
}

.search-no-results p {
	color: rgba(26,26,24,0.60);
	margin-bottom: 24px;
	font-size: 1.05rem;
}

/* ==========================================================================
   404 Page — Brand-wash background overrides
   ========================================================================== */
.error-404 {
	background: var(--c-brand-wash);
	background-image: linear-gradient(180deg, rgba(200,241,53,0.15) 0%, transparent 50%);
	padding: clamp(80px, 12vw, 140px) var(--container-pad) clamp(64px, 10vw, 120px);
}
/* ==========================================================================
   Blog Cards Grid — shared grid wrapper for 404, search, related contexts
   ========================================================================== */
.blog-cards-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 28px;
}

@media (max-width: 600px) {
	.blog-cards-grid {
		grid-template-columns: 1fr;
		gap: 20px;
	}
}
