/* =========================================================================
   Page / template specific styles.
   Generic page + blog layout now; Home (Phase 5) and inner pages
   (Phases 6-7) extend this file.
   ========================================================================= */

/* --- Generic inner page header --------------------------------------- */
.page-hero {
	background: var(--c-wash);
	padding-block: clamp(3rem, 2rem + 5vw, 6rem);
	text-align: center;
}
.page-hero .eyebrow { justify-content: center; }
.page-hero p { max-width: 60ch; margin-inline: auto; color: var(--color-text-muted); }

.breadcrumb {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	justify-content: center;
	font-size: var(--fs-small);
	color: var(--color-text-muted);
	margin-top: var(--sp-4);
}
.breadcrumb a { color: var(--color-primary); }

/* --- Article / single -------------------------------------------------- */
.entry {
	max-width: var(--container-narrow);
	margin-inline: auto;
}
.entry__meta {
	display: flex;
	gap: var(--sp-4);
	color: var(--color-text-muted);
	font-size: var(--fs-small);
	margin-bottom: var(--sp-5);
}
.entry-content > * + * { margin-top: var(--sp-5); }
.entry-content h2, .entry-content h3 { margin-top: var(--sp-7); }
.entry-content ul, .entry-content ol { padding-left: 1.4rem; }
.entry-content li + li { margin-top: var(--sp-2); }
.entry-content a { text-decoration: underline; text-underline-offset: 0.15em; }

/* --- Post grid (blog) ------------------------------------------------- */
.post-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--sp-6);
}
.post-card { overflow: hidden; padding: 0; }
.post-card__media { aspect-ratio: 16 / 10; overflow: hidden; }
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.05); }
.post-card__body { padding: var(--sp-5); }
.post-card__title { font-size: 1.2rem; margin-bottom: var(--sp-2); }
.post-card__excerpt { color: var(--color-text-muted); font-size: 0.95rem; }

/* --- 404 -------------------------------------------------------------- */
.error-404 {
	text-align: center;
	padding-block: clamp(4rem, 2rem + 8vw, 9rem);
}
.error-404__code {
	font-family: var(--font-display);
	font-size: clamp(5rem, 3rem + 10vw, 11rem);
	font-weight: var(--fw-light);
	color: var(--c-teal-100);
	line-height: 1;
}

/* Reveal-on-scroll motion (opt-in via [data-reveal]).
   Only hidden when JS is active, so no-JS users always see content. */
html.js [data-reveal] {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity var(--t-slow) var(--ease-out), transform var(--t-slow) var(--ease-out);
}
html.js [data-reveal="left"]  { transform: translateX(-32px); }
html.js [data-reveal="right"] { transform: translateX(32px); }
html.js [data-reveal].is-visible { opacity: 1; transform: none; }
