/* =========================================================
   components.css — shared components used across templates:
   breadcrumbs, post-card, author-box, inline-cta, related-posts.
   ========================================================= */

/* ---------- Breadcrumbs ---------- */
.breadcrumbs { font-size: .85rem; color: var(--text-muted); }
.breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .35rem;
	padding-left: 0;
	margin: 0;
}
.breadcrumbs__item { display: inline-flex; align-items: center; gap: .35rem; }
.breadcrumbs__link { color: var(--text-muted); text-decoration: none; }
.breadcrumbs__link:hover { color: var(--sonix-blue); text-decoration: underline; }
.breadcrumbs__current { color: var(--text-default); }
.breadcrumbs__sep { color: var(--text-quiet); }

/* ---------- Post card ---------- */
.post-card {
	background: #fff;
	border-radius: var(--radius-card);
	overflow: hidden;
	border: 1px solid var(--surface-border);
	box-shadow: var(--shadow-card);
	transition: transform .2s ease, box-shadow .2s ease;
	display: flex;
	flex-direction: column;
}
.post-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-card-h);
}

.post-card__media {
	position: relative;
	display: block;
	aspect-ratio: 16 / 10;
	background: var(--surface-muted);
	overflow: hidden;
	text-decoration: none;
}
.post-card__media--art {
	background-image: var(--card-art);
	background-size: cover;
	background-position: center;
}
.post-card__image {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .35s ease;
}
.post-card:hover .post-card__image { transform: scale(1.04); }

.post-card__chip {
	position: absolute;
	top: var(--space-2);
	left: var(--space-2);
	background: rgba(255,255,255,.92);
	color: var(--text-strong);
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .06em;
	text-transform: uppercase;
	padding: .25rem .55rem;
	border-radius: var(--radius-pill);
	pointer-events: none;
	box-shadow: 0 2px 6px rgba(15,23,42,.12);
}

.post-card__body {
	padding: var(--space-3) var(--space-4) var(--space-4);
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}
.post-card__title {
	margin: 0;
	font-family: var(--font-prose);
	font-size: 1.2rem;
	line-height: 1.3;
	color: var(--text-strong);
}
.post-card__title a { color: inherit; text-decoration: none; }
.post-card__title a:hover { color: var(--sonix-blue); }

.post-card__excerpt {
	color: var(--text-muted);
	font-size: .95rem;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.post-card__meta {
	margin-top: auto;
	font-size: .82rem;
	color: var(--text-muted);
	display: flex;
	align-items: center;
	gap: var(--space-2);
}
.post-card__dot { color: var(--text-quiet); }

/* ---------- Inline CTA ---------- */
.inline-cta {
	margin: var(--space-7) 0 var(--space-5);
	background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 100%);
	color: #fff;
	border-radius: 18px;
	padding: var(--space-6) var(--space-5);
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--space-5);
	align-items: center;
	box-shadow: var(--shadow-cta);
}
.inline-cta__eyebrow {
	margin: 0 0 var(--space-2);
	font-size: .75rem;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: rgba(255,255,255,.75);
	font-weight: 700;
}
.inline-cta__title {
	font-family: var(--font-prose);
	font-size: 1.6rem;
	margin: 0 0 var(--space-3);
	color: #fff;
}
.inline-cta__lede {
	margin: 0 0 var(--space-3);
	color: rgba(255,255,255,.85);
	font-size: 1rem;
}
.inline-cta__features {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-4);
	color: rgba(255,255,255,.92);
	font-size: .95rem;
}
.inline-cta__features li {
	padding-left: 1.5em;
	position: relative;
	margin-bottom: .3em;
}
.inline-cta__features li::before {
	content: "✓";
	position: absolute;
	left: 0;
	color: #4ade80;
	font-weight: 700;
}
.inline-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
}
.inline-cta__proof {
	text-align: center;
	border-left: 1px solid rgba(255,255,255,.15);
	padding-left: var(--space-5);
	min-width: 160px;
}
.inline-cta__stars {
	display: block;
	color: #FFC857;
	font-size: 1.4rem;
	letter-spacing: .08em;
	margin-bottom: .3rem;
}
.inline-cta__rating {
	display: block;
	font-family: var(--font-prose);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
}
.inline-cta__sub {
	display: block;
	font-size: .85rem;
	color: rgba(255,255,255,.7);
	margin-top: .35rem;
}
@media (max-width: 760px) {
	.inline-cta {
		grid-template-columns: 1fr;
		padding: var(--space-5) var(--space-4);
	}
	.inline-cta__proof {
		border-left: 0;
		border-top: 1px solid rgba(255,255,255,.15);
		padding: var(--space-4) 0 0;
	}
}

/* ---------- Author box ---------- */
.author-box {
	display: flex;
	gap: var(--space-4);
	background: var(--surface-card);
	border: 1px solid var(--surface-border);
	border-radius: var(--radius-card);
	padding: var(--space-5);
	margin: var(--space-6) 0;
}
.author-box__avatar { flex-shrink: 0; }
.author-box__img { border-radius: 50%; width: 72px; height: 72px; }
.author-box__eyebrow {
	margin: 0 0 .25rem;
	font-size: .75rem;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--text-quiet);
	font-weight: 700;
}
.author-box__name {
	margin: 0 0 var(--space-2);
	font-family: var(--font-prose);
	font-size: 1.2rem;
}
.author-box__name a { color: var(--text-strong); text-decoration: none; }
.author-box__name a:hover { color: var(--sonix-blue); }
.author-box__bio {
	margin: 0 0 var(--space-2);
	color: var(--text-muted);
	font-size: .95rem;
}
.author-box__links {
	display: flex;
	gap: var(--space-3);
	font-size: .85rem;
	margin: 0;
}
.author-box__links a { color: var(--sonix-blue); text-decoration: none; }
.author-box__links a:hover { text-decoration: underline; }

@media (max-width: 560px) {
	.author-box { flex-direction: column; }
}

/* ---------- Related posts ---------- */
.related-posts {
	margin: var(--space-7) 0;
}
.related-posts__title {
	font-family: var(--font-prose);
	font-size: 1.5rem;
	margin: 0 0 var(--space-4);
}
.related-posts__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-4);
}
@media (max-width: 900px) {
	.related-posts__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
	.related-posts__grid { grid-template-columns: 1fr; }
}

/* ---------- No-results / 404 helpers ---------- */
.no-results {
	max-width: 540px;
	margin: var(--space-7) auto;
	text-align: center;
}
.no-results__title { font-family: var(--font-prose); font-size: 1.5rem; margin-bottom: var(--space-3); }
.no-results__copy { color: var(--text-muted); margin-bottom: var(--space-4); }
