/* ============================================================
   MOBILE MENU
   ============================================================ */

.mobile-menu {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(360px, 100vw);
	background-color: var(--color-white);
	z-index: 200;
	transform: translateX(100%);
	transition: transform 300ms ease;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.mobile-menu.is-open {
	transform: translateX(0);
}

.mobile-menu__inner {
	padding: var(--space-6) var(--space-6) var(--space-12);
	display: flex;
	flex-direction: column;
	min-height: 100%;
}

.mobile-menu__close {
	align-self: flex-end;
	font-size: 1.5rem;
	color: var(--color-charcoal);
	padding: var(--space-2);
	line-height: 1;
	margin-bottom: var(--space-6);
}

.mobile-menu__close:hover {
	color: var(--color-navy);
}

.mobile-menu__list {
	flex: 1;
}

.mobile-menu__list li {
	border-bottom: 1px solid var(--color-border);
}

.mobile-menu__list a {
	display: block;
	padding: var(--space-4) 0;
	font-size: var(--text-lg);
	font-weight: 500;
	color: var(--color-charcoal);
	text-decoration: none;
}

.mobile-menu__list a:hover {
	color: var(--color-navy);
}

.mobile-menu__cta {
	padding-top: var(--space-8);
}

.mobile-menu__cta .btn {
	width: 100%;
	justify-content: center;
}

.mobile-menu__overlay {
	position: fixed;
	inset: 0;
	background-color: var(--color-overlay);
	z-index: 199;
	opacity: 0;
	pointer-events: none;
	transition: opacity 300ms ease;
}

.mobile-menu__overlay.is-visible {
	opacity: 1;
	pointer-events: auto;
}

.site-header.is-scrolled {
	box-shadow: var(--shadow-md);
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */

.breadcrumb {
	margin-bottom: var(--space-6);
}

.breadcrumb-list {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	list-style: none;
	padding: 0;
	margin: 0;
	font-size: var(--text-sm);
}

.breadcrumb-item {
	display: flex;
	align-items: center;
	color: var(--color-gray);
}

.breadcrumb-item + .breadcrumb-item::before {
	content: '/';
	margin: 0 var(--space-2);
	color: var(--color-gray-light);
	flex-shrink: 0;
}

.breadcrumb-item a {
	color: var(--color-gray);
	text-decoration: none;
	transition: color var(--transition);
}

.breadcrumb-item a:hover {
	color: var(--color-navy);
}

.breadcrumb-item.current {
	color: var(--color-charcoal);
}

/* Page-hero override: navy background requires white breadcrumbs */
.page-hero .breadcrumb-item,
.page-hero .breadcrumb-item a {
	color: var(--color-white-60);
}

.page-hero .breadcrumb-item a:hover {
	color: var(--color-white);
}

.page-hero .breadcrumb-item + .breadcrumb-item::before {
	color: var(--color-white-40);
}

.page-hero .breadcrumb-item.current {
	color: var(--color-white-60);
}

/* Suppress duplicate page title — already rendered in the page hero */
.page .entry-title,
.page-template-template-service .entry-title,
.page-template-template-contact .entry-title,
.page-template-template-services-landing .entry-title {
	display: none;
}

/* ============================================================
   POST CARD
   ============================================================ */

.post-card {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-top: 3px solid var(--color-navy);
	overflow: hidden;
	transition: box-shadow var(--transition), border-top-color var(--transition), transform var(--transition);
}

.post-card:hover {
	box-shadow: var(--shadow-md);
	border-top-color: var(--color-sky);
	transform: translateY(-2px);
}

.post-card__thumbnail {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.post-card__thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms ease;
}

.post-card:hover .post-card__thumbnail img {
	transform: scale(1.03);
}

.post-card__body {
	padding: var(--space-6);
}

.post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	margin-bottom: var(--space-3);
}

.post-card__date {
	font-size: var(--text-xs);
	color: var(--color-gray);
	font-weight: 500;
}

.category-badge {
	display: inline-block;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--color-navy);
	background-color: var(--color-navy-08);
	padding: 2px 8px;
}

.post-card__title {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: var(--space-3);
	line-height: 1.3;
}

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

.post-card__title a:hover {
	color: var(--color-sky);
}

.post-card__excerpt {
	font-size: var(--text-sm);
	color: var(--color-gray);
	line-height: 1.7;
	margin-bottom: var(--space-4);
}

.post-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-4);
	margin-top: var(--space-4);
}

.post-card__read-time {
	font-size: var(--text-xs);
	color: var(--color-gray);
}

.post-card__link {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-navy);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	display: inline-flex;
	align-items: center;
	gap: var(--space-1);
	text-decoration: none;
	border-bottom: 1px solid var(--color-sky);
	padding-bottom: 1px;
	transition: color var(--transition);
}

.post-card__link::after {
	content: '→';
}

.post-card__link:hover {
	color: var(--color-sky);
}

/* ============================================================
   AUTHOR BIO
   ============================================================ */

.author-bio {
	display: flex;
	gap: var(--space-6);
	padding: var(--space-8);
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	margin-top: var(--space-12);
}

.author-bio__avatar {
	flex-shrink: 0;
}

.author-bio__avatar img {
	width: 80px;
	height: 80px;
	object-fit: cover;
}

.author-bio__name {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: var(--space-2);
}

.author-bio__description {
	font-size: var(--text-sm);
	color: var(--color-gray);
	line-height: 1.7;
	margin-bottom: 0;
}

/* ============================================================
   PAGINATION
   ============================================================ */

.pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-2);
	margin-top: var(--space-12);
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: 1px solid var(--color-border);
	font-size: var(--text-sm);
	font-weight: 500;
	color: var(--color-charcoal);
	transition: background-color var(--transition), color var(--transition), border-color var(--transition);
	text-decoration: none;
}

.pagination .page-numbers:hover,
.pagination .page-numbers.current {
	background-color: var(--color-navy);
	color: var(--color-white);
	border-color: var(--color-navy);
}

.pagination .page-numbers.dots {
	border-color: transparent;
	background: none;
	cursor: default;
	color: var(--color-gray-light);
}

.pagination .prev,
.pagination .next {
	width: auto;
	padding: 0 var(--space-4);
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* ============================================================
   SECTION HEADER UTILITY
   ============================================================ */

.section-header {
	margin-bottom: var(--space-12);
}

.section-header--center {
	text-align: center;
}

.section-header--center .eyebrow {
	display: flex;
	justify-content: center;
}

.section-header--center .divider {
	margin: var(--space-4) auto var(--space-6);
}

.section-header h2 {
	margin-bottom: var(--space-4);
}

.section-header .lead {
	max-width: 640px;
}

.section-header--center .lead {
	margin-left: auto;
	margin-right: auto;
}

/* ============================================================
   SINGLE POST / PAGE LAYOUT
   ============================================================ */

.entry-layout {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: var(--space-12);
	align-items: start;
}

.entry-header {
	margin-bottom: var(--space-8);
}

.entry-header__meta {
	display: flex;
	align-items: center;
	gap: var(--space-4);
	margin-bottom: var(--space-6);
	flex-wrap: wrap;
}

.entry-header__date {
	font-size: var(--text-sm);
	color: var(--color-gray);
}

.entry-header__read-time {
	font-size: var(--text-sm);
	color: var(--color-gray);
}

.entry-header__title {
	margin-bottom: var(--space-6);
}

.entry-header__featured {
	margin-bottom: var(--space-8);
}

.entry-header__featured img {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 6;
	object-fit: cover;
}

.sidebar-widget {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	padding: var(--space-6);
	margin-bottom: var(--space-6);
}

.sidebar-widget__title {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-charcoal);
	margin-bottom: var(--space-4);
}

.sidebar-widget__list {
	list-style: none;
}

.sidebar-widget__list li {
	border-bottom: 1px solid var(--color-border);
}

.sidebar-widget__list li:last-child {
	border-bottom: none;
}

.sidebar-widget__list a {
	display: block;
	padding: var(--space-3) 0;
	font-size: var(--text-sm);
	color: var(--color-charcoal);
	text-decoration: none;
	transition: color var(--transition);
}

.sidebar-widget__list a:hover {
	color: var(--color-navy);
}

@media (max-width: 1024px) {
	.entry-layout {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

.contact-layout {
	display: grid;
	grid-template-columns: 1fr 420px;
	gap: var(--space-12);
	align-items: start;
}

.contact-form-wrap {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	padding: var(--space-8);
}

.contact-form-wrap h2 {
	margin-bottom: var(--space-2);
}

.contact-form-wrap > p {
	color: var(--color-gray);
	margin-bottom: var(--space-8);
}

.form-notice {
	padding: var(--space-4) var(--space-6);
	background-color: var(--color-surface);
	border-left: 3px solid var(--color-navy);
	font-size: var(--text-sm);
	color: var(--color-charcoal);
	margin-bottom: var(--space-6);
}

.form-notice--success {
	border-left-color: var(--color-success-border);
	background-color: var(--color-success-bg);
	color: var(--color-success);
}

.form-notice--error {
	border-left-color: var(--color-error-border);
	background-color: var(--color-error-bg);
	color: var(--color-error);
}

/* Neutral notice for form-unavailable state (not a user error) */
.form-notice--unavailable {
	border-left-color: var(--color-logo-gray);
	background-color: var(--color-bg-cloud);
	color: var(--color-text-primary);
}

.contact-info-card {
	background-color: var(--color-navy);
	padding: var(--space-8);
	color: var(--color-sky-light);
}

.contact-info-card h3 {
	color: var(--color-white);
	margin-bottom: var(--space-6);
}

.contact-info-item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-4);
	margin-bottom: var(--space-6);
}

.contact-info-item svg {
	width: 20px;
	height: 20px;
	color: var(--color-sky);
	flex-shrink: 0;
	margin-top: 2px;
}

.contact-info-item__label {
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-sky);
	display: block;
	margin-bottom: var(--space-1);
}

.contact-info-item__value {
	font-size: var(--text-base);
	color: var(--color-white);
}

.contact-info-item__value a {
	color: inherit;
	text-decoration: none;
}

.contact-info-item__value a:hover {
	color: var(--color-sky);
}

.contact-map {
	margin-top: var(--space-6);
	border-top: 1px solid var(--color-white-15);
	padding-top: var(--space-6);
}

.contact-map iframe {
	width: 100%;
	height: 220px;
	border: none;
	display: block;
}

@media (max-width: 1024px) {
	.contact-layout {
		grid-template-columns: 1fr;
	}
}

/* ============================================================
   SERVICE PAGE TEMPLATE
   ============================================================ */

.service-details {
	padding: var(--space-16) 0;
}

.service-details__list {
	list-style: none;
}

.service-details__list li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	padding: var(--space-4) 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--text-base);
	color: var(--color-charcoal);
}

.service-details__list li::before {
	content: '';
	display: block;
	width: 20px;
	height: 20px;
	background-color: var(--color-sky);
	flex-shrink: 0;
	margin-top: 2px;
	clip-path: polygon(20% 50%, 40% 70%, 80% 30%, 85% 35%, 40% 80%, 15% 55%);
}

/* ============================================================
   404 PAGE
   ============================================================ */

.error-404-wrap {
	text-align: center;
	padding: var(--space-32) 0;
}

.error-404-wrap__code {
	font-family: var(--font-display);
	font-size: 8rem;
	font-weight: 700;
	line-height: 1;
	color: var(--color-navy);
	opacity: 0.12;
	display: block;
	margin-bottom: var(--space-4);
}

.error-404-wrap__title {
	font-size: var(--text-3xl);
	color: var(--color-navy);
	margin-bottom: var(--space-4);
}

.error-404-wrap__text {
	color: var(--color-gray);
	max-width: 480px;
	margin: 0 auto var(--space-8);
}

.error-404-wrap__actions {
	display: flex;
	gap: var(--space-4);
	justify-content: center;
	flex-wrap: wrap;
}

/* ============================================================
   SEARCH RESULTS
   ============================================================ */

.search-form-wrap {
	background-color: var(--color-surface);
	padding: var(--space-8);
	margin-bottom: var(--space-10);
}

.search-form-wrap .search-form {
	display: flex;
	gap: var(--space-3);
}

.search-form-wrap .search-field {
	flex: 1;
	padding: var(--space-3) var(--space-4);
	border: 1px solid var(--color-border);
	font-family: var(--font-body);
	font-size: var(--text-base);
	color: var(--color-charcoal);
	border-radius: 0;
}

.search-form-wrap .search-field:focus {
	outline: none;
	border-color: var(--color-navy);
}

.search-form-wrap .search-submit {
	background-color: var(--color-navy);
	color: var(--color-white);
	border: none;
	padding: var(--space-3) var(--space-6);
	font-family: var(--font-body);
	font-size: var(--text-sm);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background-color var(--transition);
}

.search-form-wrap .search-submit:hover {
	background-color: var(--color-navy-dark);
}

.search-result-count {
	font-size: var(--text-sm);
	color: var(--color-gray);
	margin-bottom: var(--space-6);
}

.search-result-count strong {
	color: var(--color-navy);
}

/* ============================================================
   ARCHIVE PAGE
   ============================================================ */

.archive-header {
	margin-bottom: var(--space-12);
}

.archive-header__title {
	margin-bottom: var(--space-3);
}

.archive-header__description {
	color: var(--color-gray);
	font-size: var(--text-lg);
}

/* ============================================================
   SERVICE PAGE — PROBLEM SECTION
   ============================================================ */

.service-problem {
	padding: var(--space-16) 0;
	background-color: var(--color-white);
}

.service-problem__heading {
	font-size: var(--text-2xl);
	max-width: 720px;
	margin-bottom: var(--space-4);
}

/* ============================================================
   SERVICE PAGE — WHO THIS IS FOR
   ============================================================ */

.service-who {
	padding: var(--space-16) 0;
	background-color: var(--color-white);
}

.service-who h2 {
	margin-bottom: var(--space-2);
}

.who-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-8);
	margin-top: var(--space-8);
}

.who-item {
	padding: var(--space-6);
	border-left: 3px solid var(--color-sky);
	background-color: var(--color-surface);
}

.who-item h4 {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: var(--space-2);
}

.who-item p {
	font-size: var(--text-sm);
	color: var(--color-charcoal);
	line-height: 1.7;
	margin-bottom: 0;
}

/* Lone last item in an odd position spans both columns */
.who-grid .who-item:last-child:nth-child(odd) {
	grid-column: 1 / -1;
	max-width: 640px;
}

/* ============================================================
   SERVICE PAGE — WHAT WE DO CONTENT
   ============================================================ */

.service-content h3 {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	color: var(--color-navy);
	margin-bottom: var(--space-6);
}

.service-content ul {
	list-style: none;
	padding: 0;
}

/*
 * 3-column grid: [dot] [fixed-width bold term] [flexible description]
 * The anonymous text node (em-dash + description) after <strong> becomes
 * the third grid item, so all descriptions align regardless of label length.
 */
.service-content ul li {
	display: grid;
	grid-template-columns: 14px minmax(0, 210px) 1fr;
	column-gap: var(--space-4);
	align-items: start;
	padding: var(--space-4) 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--text-base);
	color: var(--color-charcoal);
	line-height: 1.65;
}

.service-content ul li::before {
	content: '';
	display: block;
	width: 6px;
	height: 6px;
	background-color: var(--color-sky);
	border-radius: 50%;
	margin-top: 9px;
	justify-self: center;
}

.service-content ul li strong {
	color: var(--color-navy);
	font-weight: 600;
}

@media (max-width: 768px) {
	.who-grid {
		grid-template-columns: 1fr;
	}

	/* Revert service list to block on narrow screens */
	.service-content ul li {
		display: block;
		padding-left: var(--space-4);
		border-left: 3px solid var(--color-sky);
		border-bottom: none;
		margin-bottom: var(--space-4);
	}

	.service-content ul li::before {
		display: none;
	}
}

/* ==========================================================================
   WHO WE WORK WITH — Homepage Section
   ========================================================================== */

.who-section {
	background-color: var(--color-navy);
	padding: var(--space-14) 0 var(--space-16);
	position: relative;
	overflow: hidden;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

/* Layered wave motif — shared with .cta-section */
.who-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url('../images/decorative-wave-dark.svg');
	background-size: 100% 100%;
	background-repeat: no-repeat;
	pointer-events: none;
	z-index: 0;
}

.who-section > .container {
	position: relative;
	z-index: 1;
}

.who-section .section-header {
	margin-bottom: var(--space-4);
}

.who-section .section-header h2 {
	color: var(--color-white);
}

.who-section .section-header .lead {
	color: var(--color-white-75);
}

.who-section .eyebrow {
	color: var(--color-accent-teal-soft);
}

.who-section .divider--center {
	background-color: var(--color-sky);
}

.who-section__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	align-items: stretch;
	gap: 1.375rem;
	margin-top: var(--space-8);
	max-width: 1120px;
	margin-inline: auto;
}

.who-section__card {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-top: 3px solid var(--color-sky);
	padding: var(--space-6);
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.who-section__icon {
	width: 48px;
	height: 48px;
	background-color: var(--color-accent-teal-soft);
	color: var(--color-brand-blue);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.who-section__card-title {
	font-family: var(--font-display);
	font-size: var(--text-lg);
	color: var(--color-navy);
	margin: 0;
	line-height: 1.3;
}

.who-section__card-text {
	font-size: var(--text-sm);
	color: var(--color-charcoal);
	line-height: 1.7;
	flex: 1;
	margin: 0;
}

.who-section__card-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-navy);
	text-decoration: none;
	margin-top: var(--space-2);
	border-bottom: 1px solid var(--color-sky);
	padding-bottom: 1px;
	transition: color var(--transition), border-color var(--transition);
}

.who-section__card-link:hover {
	color: var(--color-sky);
	border-bottom-color: var(--color-sky);
}

.who-section__footer {
	margin-top: var(--space-10);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-6);
}

.who-section__footer p {
	color: var(--color-white-80);
	font-size: var(--text-lg);
	max-width: 560px;
	margin: 0;
}

/* ==========================================================================
   SECTION — Charcoal variant (Stats row)
   ========================================================================== */

.section--charcoal {
	background-color: var(--color-brand-navy);
}

.section--charcoal .stat-item__number,
.section--charcoal .stat-item__label {
	color: var(--color-white);
}

.section--charcoal .stat-item__number {
	color: var(--color-sky);
}

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

@media (max-width: 768px) {
	.who-section__grid {
		grid-template-columns: 1fr;
		max-width: 100%;
	}

	/* Soften wave motif on small screens */
	.who-section::before {
		opacity: 0.5;
	}
}

/* ==========================================================================
   PRICING CARDS — Service Pages
   ========================================================================== */

.service-pricing {
	padding: var(--space-20) 0;
}

.pricing-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	align-items: stretch;
	gap: var(--space-6);
	margin-top: var(--space-12);
}

.pricing-card {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	padding: var(--space-8);
	display: flex;
	flex-direction: column;
	height: 100%;
}

.pricing-card--featured {
	border-top: 3px solid var(--color-navy);
	box-shadow: var(--shadow-md);
}

.pricing-card__badge {
	display: inline-block;
	background-color: var(--color-sky);
	color: var(--color-white);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 3px 10px;
	margin-bottom: var(--space-4);
}

.pricing-card__header {
	margin-bottom: var(--space-6);
}

.pricing-card__tier {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	color: var(--color-navy);
	margin: 0 0 var(--space-1);
}

.pricing-card__subtitle {
	font-size: var(--text-sm);
	color: var(--color-charcoal);
	margin: 0;
}

.pricing-card__price {
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	padding: var(--space-6) 0;
	margin-bottom: var(--space-6);
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
}

.pricing-card__starting {
	font-family: var(--font-body);
	font-size: var(--text-xs);
	font-weight: 500;
	color: var(--color-gray);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.pricing-card__amount {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	color: var(--color-navy);
	line-height: 1.2;
}

.pricing-card__features {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-6);
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.pricing-card__features li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	font-size: var(--text-sm);
	color: var(--color-charcoal);
	line-height: 1.5;
}

.pricing-card__features li::before {
	content: '';
	display: block;
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	margin-top: 1px;
	background-color: var(--color-sky);
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
	-webkit-mask-size: cover;
	mask-size: cover;
}

.pricing-card__cta {
	margin-top: auto;
	text-align: center;
	justify-content: center;
}

@media (max-width: 1024px) {
	.pricing-grid {
		grid-template-columns: 1fr;
		max-width: 480px;
		margin-left: auto;
		margin-right: auto;
	}
}

/* ============================================================
   POST TAGS
   ============================================================ */

.post-tags {
	margin-top: var(--space-8);
	display: flex;
	gap: var(--space-2);
	flex-wrap: wrap;
	align-items: center;
}

.post-tags__label {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-charcoal);
}

/* ============================================================
   POST NAVIGATION
   ============================================================ */

.post-navigation {
	display: flex;
	justify-content: space-between;
	gap: var(--space-6);
	margin-top: var(--space-10);
	padding-top: var(--space-8);
	border-top: 1px solid var(--color-border);
}

.post-navigation__link {
	font-size: var(--text-sm);
	color: var(--color-navy);
	text-decoration: none;
	transition: color var(--transition);
}

.post-navigation__link:hover {
	color: var(--color-sky);
}

.post-navigation__link--next {
	text-align: right;
	margin-left: auto;
}

/* ============================================================
   SIDEBAR CTA WIDGET
   ============================================================ */

.sidebar-widget--cta {
	background-color: var(--color-navy);
	border-color: var(--color-navy);
}

.sidebar-widget--cta .sidebar-widget__title {
	color: var(--color-white);
}

.sidebar-widget--cta p {
	color: var(--color-sky-light);
	font-size: var(--text-sm);
	margin-bottom: var(--space-4);
}

/* ============================================================
   ENGAGEMENT PRICING — Homepage Section
   ============================================================ */

.engagement-section {
	padding: var(--space-20) 0;
}

.engagement-grid {
	display: grid;
	grid-template-columns: 1.08fr 0.84fr 1.08fr;
	gap: 0;
	margin-top: var(--space-8);
	margin-bottom: var(--space-8);
}

.engagement-card {
	padding: var(--space-6) var(--space-8);
	background-color: transparent;
	border: none;
	border-left: 1px solid var(--color-border);
	cursor: default;
}

.engagement-card:first-child {
	border-left: none;
	padding-left: 0;
}

.engagement-card__title {
	font-family: var(--font-body);
	font-size: var(--text-lg);
	font-weight: 600;
	color: var(--color-navy);
	margin-bottom: var(--space-3);
}

.engagement-card__text {
	font-size: var(--text-sm);
	line-height: 1.7;
	color: var(--color-charcoal);
	margin-bottom: 0;
}

.engagement-footer {
	text-align: center;
	padding-top: var(--space-8);
	border-top: 1px solid var(--color-border);
}

.engagement-footer p {
	color: var(--color-gray);
	margin-bottom: var(--space-4);
}

@media (max-width: 768px) {
	.engagement-grid {
		grid-template-columns: 1fr;
	}

	.engagement-card {
		border-left: none;
		padding: var(--space-5) 0;
	}

	.engagement-card + .engagement-card {
		border-top: 1px solid var(--color-border);
	}

	.engagement-card:first-child {
		padding-left: 0;
	}
}

/* ============================================================
   FAYE INTRODUCTION — Homepage Section
   ============================================================ */

.faye-split {
	display: grid;
	grid-template-columns: minmax(300px, 320px) 1fr;
	gap: var(--space-14);
	align-items: start;
}

.faye-split__image {
	position: relative;
	border-radius: 24px;
	/* overflow removed — image clips via border-radius on img directly */
}

/* Pale-blue offset panel peeking behind portrait */
.faye-split__image::before {
	content: '';
	position: absolute;
	inset: 0;
	transform: translate(16px, 16px);
	background: var(--color-bg-blue-soft);
	border-radius: 28px;
	z-index: 0;
}

.faye-split__image img {
	width: 100%;
	height: 460px;
	object-fit: cover;
	object-position: top center;
	display: block;
	border-radius: 24px;
	position: relative;
	z-index: 1;
}

.faye-split__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.faye-split__content .btn {
	align-self: flex-start;
}

.faye-split__content--full {
	max-width: 680px;
	margin-left: auto;
	margin-right: auto;
	grid-column: 1 / -1;
}

.faye-section__title {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-sky);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 0;
}

.faye-section__bio {
	color: var(--color-charcoal);
	line-height: 1.75;
}

@media (max-width: 900px) {
	.faye-split {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}

	.faye-split__image {
		max-width: 420px;
		margin-inline: auto;
	}

	.faye-split__image img {
		height: auto;
		max-height: none;
	}
}

/* ============================================================
   WHO WE WORK WITH — More Link
   ============================================================ */

.who-section__more-link {
	text-align: center;
	margin-bottom: var(--space-6);
}

.who-section__more-link a {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-sky);
	text-decoration: none;
	letter-spacing: 0.02em;
	transition: color var(--transition);
}

.who-section__more-link a:hover {
	color: var(--color-white);
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */

/* Section 2 — Firm Intro */
.about-intro .lead {
	color: var(--color-charcoal);
	margin-bottom: var(--space-4);
}

.about-intro p {
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
}

/* Section 3 — Who We Work With */
.about-who__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-6);
	margin-top: var(--space-10);
}

.about-who__card {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	padding: var(--space-8);
}

.about-who__icon {
	width: 52px;
	height: 52px;
	background: var(--color-sky-12);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--space-4);
	color: var(--color-sky);
}

.about-who__card-title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--color-navy);
	margin-bottom: var(--space-2);
}

.about-who__card-text {
	font-size: var(--text-base);
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
	margin: 0;
}

/* Section 4 — Approach */
.about-approach__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-8);
	margin-top: var(--space-10);
}

.about-approach__item {
	position: relative;
	padding-top: var(--space-2);
}

.about-approach__number {
	font-family: var(--font-display);
	font-size: 3.5rem;
	font-weight: var(--font-weight-bold);
	color: var(--color-navy-08);
	line-height: 1;
	margin-bottom: var(--space-3);
	letter-spacing: -0.02em;
}

.about-approach__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--color-navy);
	margin-bottom: var(--space-3);
}

.about-approach__text {
	font-size: var(--text-base);
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
	margin: 0;
}

/* Responsive */
@media (max-width: 768px) {
	.about-who__grid {
		grid-template-columns: 1fr;
		gap: var(--space-4);
	}

	.about-approach__grid {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}
}

@media (min-width: 769px) and (max-width: 1024px) {
	.about-who__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.about-approach__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ============================================================
   SERVICES LANDING PAGE
   ============================================================ */

/* Section 2 — Introduction */
.services-intro .lead {
	color: var(--color-charcoal);
	margin-bottom: var(--space-4);
}

.services-intro p {
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
}

/* Section 3 — Editorial 2×2 service grid */
.services-editorial-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-6);
	margin-top: var(--space-10);
}

.service-editorial {
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
	padding: var(--space-8);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.service-editorial__icon {
	width: 52px;
	height: 52px;
	background: var(--color-sky-12);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--color-sky);
}

.service-editorial__icon svg {
	width: 22px;
	height: 22px;
}

.service-editorial__title {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-navy);
	margin: 0;
}

.service-editorial__desc {
	font-size: var(--text-base);
	color: var(--color-charcoal);
	line-height: var(--leading-relaxed);
	margin: 0;
}

.service-editorial__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	flex: 1;
}

.service-editorial__list li {
	font-size: var(--text-sm);
	color: var(--color-gray);
	padding-left: var(--space-5);
	position: relative;
	line-height: var(--leading-relaxed);
}

.service-editorial__list li::before {
	content: '—';
	position: absolute;
	left: 0;
	color: var(--color-sky);
	font-weight: 700;
}

.service-editorial__link {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-sky);
	text-decoration: none;
	letter-spacing: 0.01em;
	transition: color var(--transition);
	margin-top: auto;
	padding-top: var(--space-2);
}

.service-editorial__link:hover {
	color: var(--color-navy);
}

/* Section 4 — Connected services flow */
.services-connected__body {
	max-width: 740px;
	margin-inline: auto;
	text-align: center;
	margin-bottom: var(--space-10);
}

.services-connected__body .lead {
	color: var(--color-charcoal);
	margin-bottom: var(--space-4);
}

.services-connected__body p {
	color: var(--color-gray);
	font-size: var(--text-sm);
	font-style: italic;
}

.services-flow {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-4);
	flex-wrap: wrap;
}

.services-flow__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-3);
	text-align: center;
}

.services-flow__icon {
	width: 64px;
	height: 64px;
	background: var(--color-bg-blue-soft);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-navy);
}

.services-flow__icon svg {
	width: 26px;
	height: 26px;
}

.services-flow__label {
	font-size: var(--text-sm);
	font-weight: var(--font-weight-semibold);
	color: var(--color-navy);
	white-space: nowrap;
}

.services-flow__arrow {
	font-size: 1.5rem;
	color: var(--color-sky);
	font-weight: 300;
	line-height: 1;
	margin-bottom: var(--space-6);
}

/* Section 5 — Audience list */
.services-audience__list {
	list-style: none;
	padding: 0;
	margin: var(--space-8) auto 0;
	max-width: 520px;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.services-audience__item {
	display: flex;
	align-items: baseline;
	gap: var(--space-3);
	font-size: var(--text-base);
	color: var(--color-charcoal);
	line-height: var(--leading-relaxed);
}

.services-audience__check {
	color: var(--color-sky);
	font-weight: var(--font-weight-bold);
	flex-shrink: 0;
	font-size: var(--text-base);
}

/* Section 6 — What to expect 2×2 grid */
.services-expect__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-6);
	margin-top: var(--space-10);
}

.services-expect__item {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	padding: var(--space-6);
	background: var(--color-bg-cloud);
	border-radius: 8px;
}

.services-expect__icon {
	width: 44px;
	height: 44px;
	background: var(--color-white);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-sky);
}

.services-expect__icon svg {
	width: 20px;
	height: 20px;
}

.services-expect__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-semibold);
	color: var(--color-navy);
	margin: 0;
}

.services-expect__text {
	font-size: var(--text-base);
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
	margin: 0;
}

/* Responsive — Services Landing */
@media (max-width: 768px) {
	.services-editorial-grid {
		grid-template-columns: 1fr;
		gap: var(--space-4);
	}

	.services-expect__grid {
		grid-template-columns: 1fr;
		gap: var(--space-4);
	}

	.services-flow {
		gap: var(--space-2);
	}

	.services-flow__arrow {
		font-size: 1.25rem;
		margin-bottom: var(--space-5);
	}

	.services-flow__label {
		font-size: var(--text-xs);
		white-space: normal;
		max-width: 64px;
	}
}

@media (min-width: 769px) and (max-width: 1024px) {
	.services-editorial-grid {
		grid-template-columns: repeat(2, 1fr);
	}

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

/* ============================================================
   SERVICE DETAIL PAGES
   ============================================================ */

/* Section 2 — Introduction */
.service-intro .reveal {
	padding: 0;
}

.service-intro__body {
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
}

.service-intro__body p {
	margin-bottom: var(--space-4);
}

.service-intro__body p:last-child {
	margin-bottom: 0;
}

/* Section 3 — What's included */
.service-includes__inner {
	display: grid;
	grid-template-columns: 340px 1fr;
	gap: var(--space-12);
	align-items: start;
}

.service-includes__header {
	position: sticky;
	top: var(--space-8);
}

.service-content ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.service-content ul li {
	display: block; /* override display:grid from the earlier homepage-list rule */
	padding: var(--space-4) var(--space-5);
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-left: 3px solid var(--color-sky);
	border-radius: 4px;
	font-size: var(--text-base);
	color: var(--color-charcoal);
	line-height: var(--leading-relaxed);
}

/* Suppress the grid-layout dot bullet; the border-left serves as the visual marker */
.service-content ul li::before {
	display: none;
}

/* Section 4 — Useful when */
.service-useful__list {
	list-style: none;
	padding: 0;
	margin: var(--space-6) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.service-useful__list li {
	display: flex;
	align-items: baseline;
	gap: var(--space-3);
	font-size: var(--text-base);
	color: var(--color-charcoal);
	line-height: var(--leading-relaxed);
}

.service-useful__list li::before {
	content: '→';
	color: var(--color-sky);
	font-weight: var(--font-weight-bold);
	flex-shrink: 0;
}

/* Section 5 — Process */
.service-process__steps {
	list-style: none;
	padding: 0;
	margin: var(--space-6) 0 0;
	counter-reset: process-step;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.service-process__step {
	counter-increment: process-step;
	display: flex;
	align-items: baseline;
	gap: var(--space-4);
	padding: var(--space-5) 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--text-base);
	color: var(--color-charcoal);
	line-height: var(--leading-relaxed);
}

.service-process__step:first-child {
	padding-top: 0;
}

.service-process__step::before {
	content: counter(process-step, decimal-leading-zero);
	font-family: var(--font-display);
	font-size: var(--text-sm);
	font-weight: var(--font-weight-bold);
	color: var(--color-sky);
	flex-shrink: 0;
	min-width: 2rem;
}

/* Section 6 — Related services */
.service-related__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-6);
	margin-top: var(--space-8);
}

.service-related__item {
	padding: var(--space-6) var(--space-8);
	background: var(--color-bg-blue-soft);
	border-radius: 8px;
}

.service-related__title {
	font-size: var(--text-lg);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--space-2);
}

.service-related__title a {
	color: var(--color-navy);
	text-decoration: none;
	transition: color var(--transition);
}

.service-related__title a:hover {
	color: var(--color-sky);
}

.service-related__excerpt {
	font-size: var(--text-sm);
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
	margin: 0;
}

/* Responsive — service detail */
@media (max-width: 900px) {
	.service-includes__inner {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}

	.service-includes__header {
		position: static;
	}
}

@media (max-width: 768px) {
	.service-related__grid {
		grid-template-columns: 1fr;
	}

	.service-related__item {
		padding: var(--space-5) var(--space-6);
	}
}

/* ============================================================
   BOOKKEEPING SERVICE TIERS
   ============================================================ */

.service-tiers__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-8);
	margin-top: var(--space-10);
}

.service-tiers__card {
	padding: var(--space-8);
	background: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: 8px;
}

.service-tiers__card--growth {
	background: var(--color-bg-blue-soft);
	border-top: 3px solid var(--color-navy);
}

.service-tiers__name {
	font-size: var(--text-xl);
	font-weight: var(--font-weight-semibold);
	color: var(--color-navy);
	margin-bottom: var(--space-3);
}

.service-tiers__desc {
	font-size: var(--text-sm);
	color: var(--color-charcoal);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-6);
}

.service-tiers__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.service-tiers__list li {
	display: flex;
	align-items: baseline;
	gap: var(--space-3);
	font-size: var(--text-sm);
	line-height: var(--leading-relaxed);
	color: var(--color-charcoal);
}

.service-tiers__list li::before {
	content: '✓';
	color: var(--color-sky);
	font-weight: var(--font-weight-bold);
	flex-shrink: 0;
	speak: none;
}

.service-tiers__note {
	margin-top: var(--space-8);
	font-size: var(--text-sm);
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
	max-width: 680px;
}

.service-tiers__cta {
	margin-top: var(--space-10);
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--space-4);
}

.service-tiers__cta p {
	font-size: var(--text-base);
	color: var(--color-charcoal);
	max-width: 560px;
	margin-bottom: 0;
}

@media (max-width: 768px) {
	.service-tiers__grid {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}
}

/* ==========================================================================
   Contact Page
   ========================================================================== */

/* Intro section */
.contact-intro .lead {
	margin-bottom: var(--space-5);
	text-wrap: balance;
}

.contact-intro__lead-in {
	margin-bottom: 0;
}

.contact-intro__list {
	list-style: disc;
	margin: var(--space-3) 0 var(--space-5);
	padding-left: var(--space-6);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}

.contact-intro__list li {
	padding-left: var(--space-2);
	line-height: var(--leading-body);
}

.contact-intro__note {
	margin-top: var(--space-5);
	color: var(--color-gray);
	font-size: var(--text-sm);
}

/* Privacy notice */
.contact-form-privacy {
	font-size: var(--text-sm);
	color: var(--color-gray);
	margin-bottom: var(--space-6);
}

.contact-form__extra-field {
	position: absolute;
	left: -10000px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* What happens next */
.contact-next__steps {
	list-style: none;
	padding: 0;
	margin: var(--space-8) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
}

.contact-next__step {
	display: grid;
	grid-template-columns: 3rem 1fr;
	gap: var(--space-4) var(--space-6);
	align-items: start;
}

.contact-next__step-number {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	border-radius: 50%;
	background: var(--color-brand-blue);
	color: #fff;
	font-size: var(--text-lg);
	font-weight: var(--font-weight-semibold);
	font-family: var(--font-display);
	flex-shrink: 0;
}

.contact-next__step strong {
	display: block;
	font-size: var(--text-lg);
	font-weight: var(--font-weight-semibold);
	margin-bottom: var(--space-2);
}

.contact-next__step p {
	margin: 0;
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
}

/* Portal section */
.contact-portal__inner {
	text-align: center;
	max-width: 600px;
	margin: 0 auto;
}

.contact-portal__inner h2 {
	margin-bottom: var(--space-4);
}

.contact-portal__inner p {
	color: var(--color-gray);
	margin-bottom: var(--space-8);
}

/* Responsive — contact page */
@media (max-width: 640px) {
	.contact-next__step {
		grid-template-columns: 2.5rem 1fr;
		gap: var(--space-3) var(--space-4);
	}

	.contact-next__step-number {
		width: 2.5rem;
		height: 2.5rem;
		font-size: var(--text-base);
	}
}

/* ==========================================================================
   Insights Platform
   ========================================================================== */

/* ------------------------------------------------------------
   Category Navigation
   ------------------------------------------------------------ */

.cat-nav {
	background-color: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.cat-nav .container {
	padding-top: 0;
	padding-bottom: 0;
}

.cat-nav__list {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 0;
	white-space: nowrap;
}

.cat-nav__item {
	flex-shrink: 0;
}

.cat-nav__link {
	display: block;
	padding: var(--space-4) var(--space-5);
	font-size: var(--text-sm);
	font-weight: 600;
	letter-spacing: 0.04em;
	color: var(--color-gray);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	transition: color var(--transition), border-color var(--transition);
}

.cat-nav__link:hover {
	color: var(--color-navy);
	border-bottom-color: var(--color-sky);
}

.cat-nav__link--active {
	color: var(--color-navy);
	border-bottom-color: var(--color-navy);
}

/* ------------------------------------------------------------
   Insights Grid — 3-col → 2-col → 1-col
   ------------------------------------------------------------ */

.insights-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-8);
	align-items: start;
}

/* ------------------------------------------------------------
   Insights Archive (empty state)
   ------------------------------------------------------------ */

.insights-empty {
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
	padding: var(--space-16) 0;
}

.insights-empty h2 {
	margin-bottom: var(--space-4);
}

.insights-empty p {
	color: var(--color-gray);
	margin-bottom: var(--space-8);
}

/* ------------------------------------------------------------
   Featured Article
   ------------------------------------------------------------ */

.insights-featured {
	background-color: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
}

.insights-featured__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-10);
	align-items: center;
}

.insights-featured__image {
	display: block;
	overflow: hidden;
	aspect-ratio: 16 / 9;
}

.insights-featured__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms ease;
}

.insights-featured__image:hover img {
	transform: scale(1.02);
}

.insights-featured__meta {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	margin-bottom: var(--space-4);
	flex-wrap: wrap;
}

.insights-featured__title {
	font-family: var(--font-display);
	font-size: clamp(var(--text-xl), 3vw, var(--text-3xl));
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.25;
	margin-bottom: var(--space-4);
}

.insights-featured__title a {
	color: inherit;
	text-decoration: none;
}

.insights-featured__title a:hover {
	color: var(--color-sky);
}

.insights-featured__excerpt {
	color: var(--color-gray);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-6);
}

/* ------------------------------------------------------------
   Article / Single Post Layout
   ------------------------------------------------------------ */

/* Prose wrapper — narrow reading measure */
.prose {
	max-width: 720px;
	margin: 0 auto;
}

/* Entry content typography */
.entry-content {
	font-size: var(--text-base);
	line-height: 1.8;
	color: var(--color-charcoal);
}

.entry-content h2 {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: 700;
	color: var(--color-navy);
	margin-top: var(--space-12);
	margin-bottom: var(--space-4);
	line-height: 1.25;
}

.entry-content h3 {
	font-family: var(--font-display);
	font-size: var(--text-xl);
	font-weight: 600;
	color: var(--color-navy);
	margin-top: var(--space-8);
	margin-bottom: var(--space-3);
}

.entry-content p {
	margin-bottom: var(--space-5);
}

.entry-content ul,
.entry-content ol {
	margin-bottom: var(--space-5);
	padding-left: var(--space-6);
}

.entry-content li {
	margin-bottom: var(--space-2);
	line-height: 1.7;
}

.entry-content blockquote {
	margin: var(--space-8) 0;
	padding: var(--space-6) var(--space-8);
	border-left: 4px solid var(--color-sky);
	background-color: var(--color-surface);
	color: var(--color-charcoal);
	font-style: italic;
}

.entry-content blockquote p {
	margin-bottom: 0;
}

.entry-content a {
	color: var(--color-navy);
	text-decoration: underline;
	text-decoration-color: var(--color-sky);
}

.entry-content a:hover {
	color: var(--color-sky);
}

.entry-content table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: var(--space-6);
	font-size: var(--text-sm);
	overflow-x: auto;
	display: block;
}

.entry-content thead th {
	background-color: var(--color-navy);
	color: var(--color-white);
	padding: var(--space-3) var(--space-4);
	text-align: left;
	font-weight: 600;
}

.entry-content tbody td {
	padding: var(--space-3) var(--space-4);
	border-bottom: 1px solid var(--color-border);
}

.entry-content tbody tr:nth-child(even) {
	background-color: var(--color-surface);
}

.entry-content figcaption {
	font-size: var(--text-sm);
	color: var(--color-gray);
	text-align: center;
	margin-top: var(--space-2);
}

.entry-content img {
	max-width: 100%;
	height: auto;
}

/* Featured image — restrained overlap into the article hero bottom pocket */
.entry-featured-image {
	margin-top: -1.25rem;   /* overlap into hero bottom padding */
	margin-bottom: 0;
	position: relative;
	z-index: 1;             /* appears above hero background decorations */
}

/* Frame: enforces 16/9 editorial crop, rounded corners, and contained width */
.entry-featured-image__frame {
	overflow: hidden;
	border-radius: 4px;
	aspect-ratio: 16 / 9;
	background-color: var(--color-bg-cloud); /* placeholder while image loads */
	box-shadow: var(--shadow-md);
	max-width: 940px;       /* wider than prose column, narrower than full container */
	margin-inline: auto;
}

.entry-featured-image__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Article tags */
.article-tags {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	flex-wrap: wrap;
	margin-top: var(--space-8);
	padding-top: var(--space-6);
	border-top: 1px solid var(--color-border);
}

.article-tags__label {
	font-size: var(--text-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-gray);
}

/* Disclaimer — quiet informational note */
.article-disclaimer {
	margin-top: var(--space-6);
	padding: var(--space-4) var(--space-5);
	background-color: var(--color-surface);
	border-left: 3px solid var(--color-border);
	font-size: var(--text-sm);
	color: var(--color-gray);
	line-height: 1.7;
}

.article-disclaimer p {
	margin: 0;
}

/* Author attribution — extensible text-only block (no Gravatar dependency) */
.article-author {
	margin-top: var(--space-6);
	padding: var(--space-4) var(--space-5);
	background-color: var(--color-surface);
	border-left: 3px solid var(--color-sky);
}

.article-author__credit {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	margin-bottom: 0;
	font-size: var(--text-sm);
}

.article-author__label {
	color: var(--color-gray);
}

.article-author__name {
	font-family: var(--font-display);
	font-weight: 600;
	color: var(--color-navy);
}

/* Optional bio line — renders only when user bio is set in WP admin */
.article-author__bio {
	font-size: var(--text-sm);
	color: var(--color-gray);
	line-height: 1.7;
	margin-top: var(--space-2);
	margin-bottom: 0;
}

/* Prev/next article navigation */
.article-nav {
	display: flex;
	gap: var(--space-6);
	justify-content: space-between;
	margin-top: var(--space-12);
	padding-top: var(--space-8);
	border-top: 1px solid var(--color-border);
	flex-wrap: wrap;
}

.article-nav__link {
	display: flex;
	flex-direction: column;
	gap: var(--space-1);
	max-width: 45%;
	text-decoration: none;
}

.article-nav__link--next {
	text-align: right;
	margin-left: auto;
}

.article-nav__dir {
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--color-gray);
}

.article-nav__title {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-navy);
	line-height: 1.4;
	transition: color var(--transition);
}

.article-nav__link:hover .article-nav__title {
	color: var(--color-sky);
}

/* Compact consultation CTA — article-specific, lighter than global cta-section */
.article-cta {
	background-color: var(--color-bg-blue-soft);
	padding: var(--space-12) 0;
}

.article-cta__inner {
	display: flex;
	align-items: center;
	gap: var(--space-10);
	max-width: 860px;
	margin-inline: auto;
}

.article-cta__text {
	flex: 1;
}

.article-cta__text h2 {
	font-size: clamp(var(--text-xl), 2.5vw, var(--text-2xl));
	margin-bottom: var(--space-3);
	color: var(--color-navy);
}

.article-cta__text p {
	color: var(--color-gray);
	margin-bottom: 0;
}

.article-cta__action {
	flex-shrink: 0;
}

/* Related insights section header */
.related-insights .section-header {
	margin-bottom: var(--space-8);
}

/* Updated date in article header */
.entry-header__updated {
	font-size: var(--text-sm);
	color: var(--color-gray);
}

/* Article body section */
.article-body {
	padding-top: var(--space-10); /* no featured image — adequate gap below hero */
}

/* When a featured image is present it visually separates hero from body */
.article-body--has-image {
	padding-top: var(--space-6);
}

/* ------------------------------------------------------------
   Responsive — Insights Platform
   ------------------------------------------------------------ */

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

@media (max-width: 900px) {
	.insights-featured__inner {
		grid-template-columns: 1fr;
		gap: var(--space-6);
	}

	.insights-featured__title {
		font-size: var(--text-2xl);
	}
}

@media (max-width: 768px) {
	.insights-grid {
		grid-template-columns: 1fr;
	}

	.insights-grid--related {
		grid-template-columns: 1fr;
	}

	.cat-nav__link {
		padding: var(--space-3) var(--space-4);
	}

	.article-nav__link {
		max-width: 100%;
	}

	.article-nav__link--next {
		text-align: left;
		margin-left: 0;
	}

	.prose {
		max-width: 100%;
	}

	/* Featured image — smaller overlap at tablet */
	.entry-featured-image {
		margin-top: -0.75rem;
	}

	/* Article CTA — stack vertically on mobile */
	.article-cta__inner {
		flex-direction: column;
		align-items: flex-start;
		gap: var(--space-5);
	}

	.article-cta__action .btn {
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 640px) {
	.entry-content h2 {
		font-size: var(--text-xl);
	}

	.entry-content h3 {
		font-size: var(--text-lg);
	}

	.insights-featured__title {
		font-size: var(--text-xl);
	}

	/* No overlap on small screens — image sits flush below hero */
	.entry-featured-image {
		margin-top: 0;
	}

	.article-cta {
		padding: var(--space-10) 0;
	}
}
