/* =========================================================
   Journey — blog.css
   Styles the custom blog index (Template: Blog Index), single
   posts, and category/search archives. Uses only design tokens
   from global.css. Loaded after global.css.
   ========================================================= */

/* ---------- Blog index (template-blog.php) ---------- */
.blog-hero { padding: 80px 0 36px; text-align: center; }
.blog-hero .eyebrow {
	display: inline-block;
	background: var(--gold-soft); color: var(--gold-deep);
	padding: 7px 16px; border-radius: 999px;
	font-size: 12px; font-weight: 600; letter-spacing: 0.06em;
	margin-bottom: 24px;
}
.blog-hero h1 {
	font-family: var(--serif);
	font-size: clamp(40px, 6vw, 68px);
	line-height: 1.04; font-weight: 500; letter-spacing: -0.03em;
	margin: 0 auto 16px; max-width: 820px;
}
.blog-hero .sub {
	font-size: 19px; color: var(--ink-mute);
	max-width: 560px; margin: 0 auto; line-height: 1.55;
}

.blog-controls { max-width: 1180px; margin: 0 auto 40px; }
.blog-search {
	position: relative; max-width: 520px; margin: 0 auto 26px;
	display: flex; align-items: center; gap: 10px;
	background: #fff; border: 1px solid var(--line);
	border-radius: 999px; padding: 8px 10px 8px 22px;
	box-shadow: 0 14px 40px -24px rgba(0,0,0,0.16);
}
.blog-search svg { width: 18px; height: 18px; flex-shrink: 0; color: var(--ink-soft); }
.blog-search input {
	flex: 1; border: none; outline: none; background: none;
	font-family: var(--sans); font-size: 16px; color: var(--ink);
	padding: 8px 0;
}
.blog-search input::placeholder { color: var(--ink-soft); }

.blog-filters { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.blog-filters .filter-chip {
	background: #fff; border: 1px solid var(--line);
	padding: 8px 14px; border-radius: 999px;
	font-size: 13px; font-weight: 500; color: var(--ink-mute);
	cursor: pointer; font-family: inherit;
	transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.blog-filters .filter-chip:hover { color: var(--ink); border-color: var(--gold-cta); }
.blog-filters .filter-chip.active { background: var(--olive); border-color: var(--olive); color: #fff; }

.blog-grid {
	display: grid; grid-template-columns: repeat(3, 1fr);
	gap: 22px; padding-bottom: 100px;
}
@media (max-width: 980px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card {
	display: flex; flex-direction: column;
	background: #fff; border: 1px solid var(--line);
	border-radius: 18px; overflow: hidden;
	text-decoration: none; color: inherit;
	transition: transform 0.18s, box-shadow 0.18s, border-color 0.18s;
}
.blog-card:hover {
	transform: translateY(-3px);
	border-color: var(--gold-cta);
	box-shadow: 0 24px 48px -28px rgba(0,0,0,0.18);
}
.bc-thumb { aspect-ratio: 16 / 9; background: var(--bg-card); overflow: hidden; }
.bc-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bc-body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.bc-cat {
	font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
	text-transform: uppercase; color: var(--gold-deep); margin-bottom: 12px;
}
.bc-title {
	font-family: var(--serif);
	font-size: 21px; font-weight: 500; line-height: 1.22;
	letter-spacing: -0.01em; color: var(--ink); margin-bottom: 12px;
}
.bc-excerpt { font-size: 14.5px; line-height: 1.55; color: var(--ink-mute); margin-bottom: 18px; flex: 1; }
.bc-meta { font-size: 12.5px; color: var(--ink-soft); margin-top: auto; }

.blog-empty { text-align: center; color: var(--ink-mute); font-size: 17px; padding: 40px 0 100px; }
.blog-index [hidden] { display: none !important; }

@media (max-width: 720px) {
	.blog-hero { padding: 56px 0 28px; }
	.blog-hero h1 { font-size: clamp(32px, 9vw, 44px); }
	.blog-hero .sub { font-size: 16px; }
}

/* ---------- Single post (prose) ----------
   global.css flush is scoped to exclude .single, so normal layout applies. */
.single-post .inside-article { border: none; box-shadow: none; }
.single-post .entry-header,
.single-post .entry-content,
.single-post .post-navigation,
.single-post .comments-area {
	max-width: 740px;
	margin-left: auto;
	margin-right: auto;
}
.single-post .entry-header { padding: 64px 0 0; }
.single-post .entry-title {
	font-family: var(--serif);
	font-size: clamp(34px, 5vw, 52px);
	line-height: 1.08; font-weight: 500; letter-spacing: -0.025em;
	color: var(--ink); margin: 0;
}
.single-post .entry-meta {
	font-size: 14px; color: var(--ink-soft); margin-top: 16px;
}
.single-post .entry-meta a { color: var(--ink-soft); text-decoration: none; }
.single-post .entry-meta a:hover { color: var(--olive); }
.single-post .post-image,
.single-post .featured-image { max-width: 980px; margin: 32px auto 0; }
.single-post .post-image img,
.single-post .featured-image img { border-radius: 16px; width: 100%; }

.single-post .entry-content {
	font-size: 18px; line-height: 1.75; color: var(--ink);
	padding: 32px 0 80px;
}
.single-post .entry-content > * { margin: 0 0 1.15em; }
.single-post .entry-content h2 {
	font-family: var(--serif); font-weight: 500;
	font-size: clamp(26px, 3.4vw, 36px); line-height: 1.2;
	letter-spacing: -0.02em; margin: 1.6em 0 0.5em;
}
.single-post .entry-content h3 {
	font-family: var(--serif); font-weight: 500;
	font-size: clamp(22px, 2.6vw, 28px); line-height: 1.25;
	margin: 1.4em 0 0.4em;
}
.single-post .entry-content h4 {
	font-family: var(--sans); font-weight: 700;
	font-size: 18px; margin: 1.4em 0 0.4em;
}
.single-post .entry-content a {
	color: var(--olive); text-decoration: underline; text-underline-offset: 2px;
}
.single-post .entry-content a:hover { color: var(--olive-deep); }
.single-post .entry-content ul,
.single-post .entry-content ol { padding-left: 1.4em; margin: 1.15em 0; }
.single-post .entry-content li { margin: 0.4em 0; }
.single-post .entry-content blockquote {
	border-left: 3px solid var(--olive-soft);
	padding: 4px 0 4px 22px; margin: 1.6em 0;
	font-family: var(--serif); font-size: 1.15em; font-style: italic;
	color: var(--ink-mute);
}
.single-post .entry-content img { border-radius: 12px; height: auto; }
.single-post .entry-content figure { margin: 1.6em 0; }
.single-post .entry-content figcaption {
	font-size: 13px; color: var(--ink-soft); text-align: center; margin-top: 8px;
}
.single-post .entry-content code {
	background: var(--bg-card-soft); border-radius: 5px;
	padding: 2px 6px; font-size: 0.9em;
}
.single-post .entry-content hr { border: none; border-top: 1px solid var(--line); margin: 2.4em 0; }

@media (max-width: 720px) {
	.single-post .entry-header { padding-top: 44px; }
	.single-post .entry-content { font-size: 17px; }
	.wrap.blog-index, .single-post .entry-content { /* lean on global .wrap padding */ }
}

/* ---------- Category / tag / search archives ----------
   Secondary to the filterable index, but kept on-brand and readable. */
.archive .page-header,
.search .page-header {
	max-width: 1180px; margin: 0 auto; padding: 72px 0 8px; text-align: center;
}
.archive .page-title,
.search .page-title {
	font-family: var(--serif); font-weight: 500;
	font-size: clamp(32px, 5vw, 52px); letter-spacing: -0.025em; color: var(--ink);
}
.archive .taxonomy-description { color: var(--ink-mute); max-width: 600px; margin: 14px auto 0; }
.archive .site-main,
.search .site-main { max-width: 760px; margin: 0 auto; padding-bottom: 80px; }
.archive .entry-header { padding-top: 40px; }
.archive .entry-title,
.search .entry-title {
	font-family: var(--serif); font-weight: 500; font-size: 26px; line-height: 1.25;
}
.archive .entry-title a,
.search .entry-title a { color: var(--ink); text-decoration: none; }
.archive .entry-title a:hover,
.search .entry-title a:hover { color: var(--olive); }
.archive .entry-summary,
.search .entry-summary { color: var(--ink-mute); line-height: 1.6; margin-top: 10px; }
.archive .entry-meta,
.search .entry-meta { font-size: 13px; color: var(--ink-soft); margin-top: 8px; }
