/* =============================================================
   sykimlaw — blog-archive.css
   Phase 4-2: Blog Card System · Archive Layout · Search UI
   Covers: index, archive, search, sidebar, pagination, meta
   ============================================================= */

/* ═══════════════════════════════════════════════════════════
   0. DESIGN TOKENS
   ═══════════════════════════════════════════════════════════ */

:root {
	--sykim-card-radius: 20px;
	--sykim-card-border:        rgba(13, 31, 60, 0.09);
	--sykim-card-border-hover:  rgba(184, 150, 46, 0.38);
	--sykim-card-shadow:        0 1px 3px rgba(13, 31, 60, 0.05), 0 2px 8px rgba(13, 31, 60, 0.04);
	--sykim-card-shadow-hover:  0 8px 28px rgba(13, 31, 60, 0.11), 0 2px 8px rgba(13, 31, 60, 0.05);
	--sykim-card-transition:    transform 250ms ease, box-shadow 250ms ease, border-color 250ms ease;
	--sykim-archive-hero-bg:    #F5F6F9;
}

/* ═══════════════════════════════════════════════════════════
   1. BLOG CARD — GRID CONTAINER
   Target: .sykim-archive-page wraps all archive/search/index
   ═══════════════════════════════════════════════════════════ */

/* — WP Query Loop grid — */
.sykim-archive-page .wp-block-post-template {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1.25rem, 2.5vw, 2rem);
	padding: 0 !important;
	margin: 0 !important;
	list-style: none !important;
}

/* ── Individual card ── */
.sykim-archive-page .wp-block-post {
	background: #FFFFFF;
	border: 1px solid var(--sykim-card-border);
	border-radius: var(--sykim-card-radius);
	overflow: hidden;
	display: flex !important;
	flex-direction: column !important;
	transition: var(--sykim-card-transition);
	box-shadow: var(--sykim-card-shadow);
}

.sykim-archive-page .wp-block-post:hover {
	transform: translateY(-4px);
	border-color: var(--sykim-card-border-hover);
	box-shadow: var(--sykim-card-shadow-hover);
}

/* ═══════════════════════════════════════════════════════════
   2. BLOG CARD — FEATURED IMAGE
   ═══════════════════════════════════════════════════════════ */

.sykim-archive-page .wp-block-post .wp-block-post-featured-image {
	overflow: hidden;
	flex-shrink: 0;
	background-color: var(--wp--preset--color--gray-50);
	/* Prevent layout shift before image loads */
	min-height: 0;
}

.sykim-archive-page .wp-block-post .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	/* Aspect ratio applied via block attribute; CSS fallback: */
	aspect-ratio: 16 / 9;
	object-fit: cover;
	transition: transform 420ms ease;
}

/* No image fallback — keep card proportions */
.sykim-archive-page .wp-block-post .wp-block-post-featured-image:empty,
.sykim-archive-page .wp-block-post .wp-block-post-featured-image a:empty {
	display: block;
	aspect-ratio: 16 / 9;
	background-color: var(--wp--preset--color--gray-50);
}

.sykim-archive-page .wp-block-post:hover .wp-block-post-featured-image img {
	transform: scale(1.03);
}

/* ═══════════════════════════════════════════════════════════
   3. BLOG CARD — BODY (inner padding group)
   ═══════════════════════════════════════════════════════════ */

.sykim-card__body {
	display: flex !important;
	flex-direction: column !important;
	flex: 1 !important;
	padding: clamp(1.125rem, 2vw, 1.625rem) !important;
	gap: 0 !important;
}

/* ─ Category badge ─ */
.sykim-card__category {
	margin-bottom: 0.75rem !important;
	padding: 0 !important;
	gap: 0 !important;
}

.sykim-card__category .wp-block-post-terms,
.sykim-card__category .wp-block-post-terms p {
	margin: 0;
	line-height: 1;
}

.sykim-card__category .wp-block-post-terms a {
	display: inline-block;
	font-family: var(--wp--preset--font-family--noto-sans-kr);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--wp--preset--color--gold-500);
	background-color: rgba(184, 150, 46, 0.09);
	padding: 0.25rem 0.5625rem;
	border-radius: 3px;
	text-decoration: none;
	transition: background-color 200ms ease, color 200ms ease;
}

.sykim-card__category .wp-block-post-terms a:hover {
	background-color: rgba(184, 150, 46, 0.17);
	color: var(--wp--preset--color--navy-900);
}

/* ─ Post title ─ */
.sykim-archive-page .wp-block-post .wp-block-post-title {
	font-family: var(--wp--preset--font-family--noto-serif-kr);
	font-size: clamp(0.9375rem, 0.6rem + 1vw, 1.125rem);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: -0.012em;
	margin-bottom: 0.75rem !important;
	word-break: keep-all;
	overflow-wrap: anywhere;
}

.sykim-archive-page .wp-block-post .wp-block-post-title a {
	color: var(--wp--preset--color--navy-900);
	text-decoration: none;
	transition: color 220ms ease;
}

.sykim-archive-page .wp-block-post:hover .wp-block-post-title a {
	color: var(--wp--preset--color--gold-500);
}

/* ─ Post excerpt ─ */
.sykim-archive-page .wp-block-post .wp-block-post-excerpt {
	flex: 1 !important;
	margin-bottom: 1rem !important;
}

.sykim-archive-page .wp-block-post .wp-block-post-excerpt p,
.sykim-archive-page .wp-block-post .wp-block-post-excerpt__excerpt {
	font-size: clamp(0.8125rem, 0.5rem + 0.8vw, 0.9375rem);
	line-height: 1.82;
	color: rgba(45, 51, 65, 0.72);
	margin: 0 !important;
	/* 3-line clamp */
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	word-break: keep-all;
	overflow-wrap: anywhere;
}

/* Suppress "Read more" link */
.sykim-archive-page .wp-block-post .wp-block-post-excerpt__more-link {
	display: none !important;
}

/* ─ Meta row ─ */
.sykim-card__meta {
	display: flex !important;
	align-items: center !important;
	gap: 0.5rem !important;
	padding-top: 0.875rem !important;
	padding-bottom: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	border-top: 1px solid rgba(13, 31, 60, 0.07) !important;
	margin-top: auto !important;
}

.sykim-card__meta .wp-block-post-date,
.sykim-card__meta time {
	font-family: 'Inter', var(--wp--preset--font-family--inter, sans-serif);
	font-size: 0.75rem;
	color: rgba(45, 51, 65, 0.48);
	letter-spacing: 0.01em;
}

/* Reading time placeholder */
.sykim-card__reading-time {
	font-size: 0.75rem;
	color: rgba(45, 51, 65, 0.42);
}

.sykim-card__reading-time::before {
	content: "·";
	margin-right: 0.35rem;
	color: rgba(45, 51, 65, 0.3);
}

/* ═══════════════════════════════════════════════════════════
   4. ARCHIVE HERO
   Used on archive.html — category / tag / author / date
   ═══════════════════════════════════════════════════════════ */

.sykim-archive-hero {
	background-color: var(--sykim-archive-hero-bg);
	padding: clamp(2.5rem, 5vw, 4.5rem) var(--wp--preset--spacing--md, 1.5rem);
	text-align: center;
	border-bottom: 1px solid rgba(13, 31, 60, 0.07);
}

/* WP renders the archive title via wp:query-title block */
.sykim-archive-hero .wp-block-query-title {
	font-family: var(--wp--preset--font-family--noto-serif-kr);
	font-size: clamp(1.5rem, 1rem + 2.2vw, 2.375rem) !important;
	font-weight: 700 !important;
	line-height: 1.25 !important;
	letter-spacing: -0.022em;
	color: var(--wp--preset--color--navy-900) !important;
	margin: 0 0 0.75rem 0 !important;
	word-break: keep-all;
}

/* WP renders term description via wp:term-description block */
.sykim-archive-hero .wp-block-term-description {
	font-size: clamp(0.9375rem, 0.6rem + 0.85vw, 1.0625rem);
	line-height: 1.75;
	color: rgba(45, 51, 65, 0.62);
	max-width: 540px;
	margin: 0 auto !important;
	word-break: keep-all;
}

.sykim-archive-hero .wp-block-term-description p {
	margin: 0;
}

/* Gold accent divider */
.sykim-archive-hero .wp-block-separator {
	width: 2.5rem !important;
	height: 2px !important;
	border: none !important;
	background-color: var(--wp--preset--color--gold-500) !important;
	margin: 1.5rem auto 0 !important;
	opacity: 1 !important;
}

/* Blog index hero (used in index.html / home.html) */
.sykim-blog-hero {
	background-color: var(--sykim-archive-hero-bg);
	padding: clamp(2.5rem, 5vw, 4rem) var(--wp--preset--spacing--md, 1.5rem);
	border-bottom: 1px solid rgba(13, 31, 60, 0.07);
}

.sykim-blog-hero__label {
	display: block;
	font-size: 0.75rem;
	font-family: var(--wp--preset--font-family--noto-sans-kr);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wp--preset--color--gold-500);
	margin-bottom: 0.625rem;
}

.sykim-blog-hero__title {
	font-family: var(--wp--preset--font-family--noto-serif-kr);
	font-size: clamp(1.5rem, 1rem + 2vw, 2.25rem);
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: -0.022em;
	color: var(--wp--preset--color--navy-900);
	margin: 0 0 0.625rem 0;
	word-break: keep-all;
}

.sykim-blog-hero__desc {
	font-size: clamp(0.9375rem, 0.6rem + 0.75vw, 1rem);
	line-height: 1.75;
	color: rgba(45, 51, 65, 0.6);
	max-width: 480px;
	word-break: keep-all;
}

/* ═══════════════════════════════════════════════════════════
   5. ARCHIVE PAGE WRAPPER + QUERY SPACING
   ═══════════════════════════════════════════════════════════ */

.sykim-archive-page {
	padding-top: 0 !important;
	padding-bottom: clamp(3rem, 6vw, 6rem) !important;
}

.sykim-query-wrap {
	padding-top: clamp(2.5rem, 4vw, 3.75rem);
}

/* ═══════════════════════════════════════════════════════════
   6. PAGINATION
   ═══════════════════════════════════════════════════════════ */

.sykim-archive-page .wp-block-query-pagination,
.wp-block-query-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.375rem;
	margin-top: clamp(2.5rem, 5vw, 4rem);
	flex-wrap: wrap;
}

/* All page number items */
.wp-block-query-pagination-numbers .page-numbers,
.wp-block-query-pagination > a,
.wp-block-query-pagination .wp-block-query-pagination-previous,
.wp-block-query-pagination .wp-block-query-pagination-next {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 0.625rem;
	border-radius: 8px;
	font-family: 'Inter', sans-serif;
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--wp--preset--color--navy-900);
	text-decoration: none;
	background-color: transparent;
	border: 1px solid rgba(13, 31, 60, 0.13);
	transition: background-color 200ms ease, border-color 200ms ease, color 200ms ease;
}

.wp-block-query-pagination-numbers .page-numbers:hover,
.wp-block-query-pagination > a:hover,
.wp-block-query-pagination .wp-block-query-pagination-previous:hover,
.wp-block-query-pagination .wp-block-query-pagination-next:hover {
	background-color: rgba(13, 31, 60, 0.05);
	border-color: rgba(13, 31, 60, 0.22);
}

/* Active page — gold accent */
.wp-block-query-pagination-numbers .page-numbers.current {
	background-color: var(--wp--preset--color--navy-900);
	border-color: var(--wp--preset--color--navy-900);
	color: #FFFFFF;
	cursor: default;
}

/* Dots separator */
.wp-block-query-pagination-numbers .page-numbers.dots {
	border-color: transparent;
	background: transparent;
	cursor: default;
	color: rgba(45, 51, 65, 0.4);
}

.wp-block-query-pagination-numbers .page-numbers.dots:hover {
	background: transparent;
	border-color: transparent;
}

/* ═══════════════════════════════════════════════════════════
   7. SEARCH HERO
   ═══════════════════════════════════════════════════════════ */

.sykim-search-hero {
	background-color: var(--sykim-archive-hero-bg);
	padding: clamp(2rem, 4.5vw, 4rem) var(--wp--preset--spacing--md, 1.5rem);
	text-align: center;
	border-bottom: 1px solid rgba(13, 31, 60, 0.07);
}

.sykim-search-hero__eyebrow {
	display: block;
	font-size: 0.75rem;
	font-family: var(--wp--preset--font-family--noto-sans-kr);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--wp--preset--color--gold-500);
	margin-bottom: 0.5rem;
}

/* WP renders search query title via wp:query-title {"type":"search"} */
.sykim-search-hero .wp-block-query-title {
	font-family: var(--wp--preset--font-family--noto-serif-kr);
	font-size: clamp(1.375rem, 0.75rem + 2vw, 1.875rem) !important;
	font-weight: 700 !important;
	line-height: 1.3 !important;
	letter-spacing: -0.018em;
	color: var(--wp--preset--color--navy-900) !important;
	margin: 0 0 0.5rem 0 !important;
	word-break: keep-all;
}

.sykim-search-hero__hint {
	font-size: 0.9375rem;
	color: rgba(45, 51, 65, 0.55);
	line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════
   8. SEARCH EMPTY STATE
   ═══════════════════════════════════════════════════════════ */

.sykim-search-empty {
	text-align: center;
	padding: clamp(3rem, 6vw, 5.5rem) var(--wp--preset--spacing--md, 1.5rem);
	max-width: 560px;
	margin: 0 auto;
}

.sykim-search-empty__icon {
	font-size: 2.25rem;
	display: block;
	margin-bottom: 1.5rem;
	opacity: 0.28;
	line-height: 1;
}

.sykim-search-empty__title {
	font-family: var(--wp--preset--font-family--noto-serif-kr);
	font-size: clamp(1.125rem, 0.7rem + 1.4vw, 1.5rem);
	font-weight: 700;
	color: var(--wp--preset--color--navy-900);
	margin: 0 0 0.875rem 0;
	line-height: 1.4;
	word-break: keep-all;
}

.sykim-search-empty__text {
	font-size: clamp(0.875rem, 0.6rem + 0.7vw, 0.9375rem);
	line-height: 1.82;
	color: rgba(45, 51, 65, 0.6);
	margin: 0 0 2rem 0;
	word-break: keep-all;
}

.sykim-search-empty__nav-label {
	display: block;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: rgba(45, 51, 65, 0.45);
	margin-bottom: 0.875rem;
}

.sykim-search-empty__links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
	margin-bottom: 2rem;
	list-style: none;
	padding: 0;
}

.sykim-search-empty__link {
	display: inline-block;
	padding: 0.4375rem 0.875rem;
	border-radius: 5px;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--wp--preset--color--navy-900);
	border: 1px solid rgba(13, 31, 60, 0.14);
	text-decoration: none;
	transition: background-color 200ms ease, border-color 200ms ease, color 200ms ease;
	line-height: 1.5;
}

.sykim-search-empty__link:hover {
	background-color: rgba(13, 31, 60, 0.04);
	border-color: rgba(13, 31, 60, 0.24);
}

.sykim-search-empty__cta {
	display: inline-block;
	padding: 0.75rem 2rem;
	background-color: var(--wp--preset--color--navy-900);
	color: #FFFFFF;
	border-radius: 4px;
	font-size: 0.9375rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	text-decoration: none;
	transition: background-color 220ms ease, transform 220ms ease;
}

.sykim-search-empty__cta:hover {
	background-color: #142B55;
	transform: translateY(-2px);
	color: #FFFFFF;
}

/* WP's wp:query-no-results block wrapper */
.sykim-archive-page .wp-block-query-no-results {
	padding: clamp(2.5rem, 5vw, 4rem) 0;
}

/* ═══════════════════════════════════════════════════════════
   9. SIDEBAR COMPONENTS — recent posts, categories, tags
   (Used in sidebar widget areas or inside article.css layout)
   ═══════════════════════════════════════════════════════════ */

/* ─ Widget title label ─ */
.sykim-widget__title {
	font-family: var(--wp--preset--font-family--noto-sans-kr);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: rgba(45, 51, 65, 0.48);
	margin: 0 0 1rem 0;
	padding-bottom: 0.625rem;
	border-bottom: 1px solid rgba(13, 31, 60, 0.09);
}

/* ─ Recent posts ─ */
.sykim-recent-posts {
	list-style: none;
	padding: 0;
	margin: 0;
}

.sykim-recent-posts__item {
	padding: 0.75rem 0;
	border-bottom: 1px solid rgba(13, 31, 60, 0.06);
}

.sykim-recent-posts__item:first-child {
	padding-top: 0;
}

.sykim-recent-posts__item:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.sykim-recent-posts__link {
	display: block;
	font-size: 0.9375rem;
	font-weight: 500;
	line-height: 1.55;
	color: var(--wp--preset--color--navy-900);
	text-decoration: none;
	word-break: keep-all;
	transition: color 200ms ease;
}

.sykim-recent-posts__link:hover {
	color: var(--wp--preset--color--gold-500);
}

.sykim-recent-posts__date {
	display: block;
	font-family: 'Inter', sans-serif;
	font-size: 0.75rem;
	color: rgba(45, 51, 65, 0.42);
	margin-top: 0.25rem;
}

/* ─ Categories list ─ */
.sykim-categories {
	list-style: none;
	padding: 0;
	margin: 0;
}

.sykim-categories__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.5rem 0;
	border-bottom: 1px solid rgba(13, 31, 60, 0.06);
}

.sykim-categories__item:first-child {
	padding-top: 0;
}

.sykim-categories__item:last-child {
	border-bottom: none;
}

.sykim-categories__link {
	font-size: 0.9375rem;
	color: var(--wp--preset--color--navy-900);
	text-decoration: none;
	transition: color 200ms ease;
	word-break: keep-all;
}

.sykim-categories__link:hover {
	color: var(--wp--preset--color--gold-500);
}

.sykim-categories__count {
	font-family: 'Inter', sans-serif;
	font-size: 0.75rem;
	color: rgba(45, 51, 65, 0.38);
	flex-shrink: 0;
}

/* ─ Tag cloud ─ */
.sykim-tags,
.wp-block-tag-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4375rem;
}

.sykim-tags a,
.wp-block-tag-cloud a {
	display: inline-block;
	padding: 0.3125rem 0.6875rem;
	border-radius: 4px;
	font-size: 0.8125rem !important;
	font-weight: 500;
	color: var(--wp--preset--color--navy-900);
	border: 1px solid rgba(13, 31, 60, 0.13);
	text-decoration: none;
	line-height: 1.5;
	transition: background-color 200ms ease, border-color 200ms ease, color 200ms ease;
}

.sykim-tags a:hover,
.wp-block-tag-cloud a:hover {
	background-color: rgba(13, 31, 60, 0.04);
	border-color: rgba(184, 150, 46, 0.38);
	color: var(--wp--preset--color--gold-500);
}

/* ═══════════════════════════════════════════════════════════
   10. AUTHOR BOX
   ═══════════════════════════════════════════════════════════ */

.sykim-author-box {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
	padding: 1.625rem;
	background-color: #F5F6F9;
	border-radius: 12px;
	border: 1px solid rgba(13, 31, 60, 0.08);
	margin: 2.5rem 0;
}

.sykim-author-box__avatar img {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	display: block;
}

.sykim-author-box__content {
	flex: 1;
	min-width: 0;
}

.sykim-author-box__label {
	display: block;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--wp--preset--color--gold-500);
	margin-bottom: 0.25rem;
}

.sykim-author-box__name {
	font-family: var(--wp--preset--font-family--noto-sans-kr);
	font-size: 1rem;
	font-weight: 700;
	color: var(--wp--preset--color--navy-900);
	margin: 0 0 0.5rem 0;
}

.sykim-author-box__bio {
	font-size: 0.9375rem;
	line-height: 1.75;
	color: rgba(45, 51, 65, 0.68);
	word-break: keep-all;
	margin: 0;
}

/* ═══════════════════════════════════════════════════════════
   11. RELATED POSTS SECTION
   Augments the existing patterns/related-posts.php pattern
   ═══════════════════════════════════════════════════════════ */

.sykim-related-section {
	margin-top: 3rem;
	padding-top: 2.5rem;
	border-top: 1px solid rgba(13, 31, 60, 0.09);
}

.sykim-related-section__heading {
	font-family: var(--wp--preset--font-family--noto-sans-kr);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: rgba(45, 51, 65, 0.45);
	margin: 0 0 1.5rem 0;
}

/* Related posts grid inherits .sykim-archive-page card system
   when the containing div has class="sykim-archive-page" */

/* ═══════════════════════════════════════════════════════════
   12. META BADGES
   ═══════════════════════════════════════════════════════════ */

.sykim-badge {
	display: inline-block;
	padding: 0.25rem 0.5625rem;
	border-radius: 3px;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.5;
	text-decoration: none;
}

.sykim-badge--category {
	color: var(--wp--preset--color--gold-500);
	background-color: rgba(184, 150, 46, 0.09);
}

.sykim-badge--category:hover {
	background-color: rgba(184, 150, 46, 0.17);
}

.sykim-badge--tag {
	color: var(--wp--preset--color--navy-900);
	background-color: rgba(13, 31, 60, 0.06);
	border: 1px solid rgba(13, 31, 60, 0.1);
}

.sykim-badge--tag:hover {
	background-color: rgba(13, 31, 60, 0.1);
}

/* ═══════════════════════════════════════════════════════════
   13. BREADCRUMB
   ═══════════════════════════════════════════════════════════ */

.sykim-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.375rem;
	font-size: 0.8125rem;
	color: rgba(45, 51, 65, 0.48);
	font-family: var(--wp--preset--font-family--noto-sans-kr);
	margin-bottom: 1.5rem;
}

.sykim-breadcrumb a {
	color: rgba(45, 51, 65, 0.48);
	text-decoration: none;
	transition: color 200ms ease;
}

.sykim-breadcrumb a:hover {
	color: var(--wp--preset--color--gold-500);
}

.sykim-breadcrumb__sep {
	color: rgba(45, 51, 65, 0.28);
	font-size: 0.5625rem;
}

.sykim-breadcrumb__current {
	color: var(--wp--preset--color--navy-900);
	font-weight: 500;
}

/* ═══════════════════════════════════════════════════════════
   14. NO POSTS PLACEHOLDER
   ═══════════════════════════════════════════════════════════ */

.sykim-no-posts {
	text-align: center;
	padding: clamp(3rem, 7vw, 5rem) 1.5rem;
	color: rgba(45, 51, 65, 0.5);
	font-size: 0.9375rem;
	line-height: 1.75;
	word-break: keep-all;
}

/* ═══════════════════════════════════════════════════════════
   15. RESPONSIVE — Tablet (≤ 900px)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
	.sykim-archive-page .wp-block-post-template {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 1.25rem !important;
	}

	.sykim-archive-hero {
		padding: 2.25rem 1.25rem;
	}

	.sykim-search-hero {
		padding: 2rem 1.25rem;
	}

	.sykim-author-box {
		gap: 1rem;
	}

	/* Pagination: keep minimum touch target */
	.wp-block-query-pagination-numbers .page-numbers,
	.wp-block-query-pagination > a,
	.wp-block-query-pagination .wp-block-query-pagination-previous,
	.wp-block-query-pagination .wp-block-query-pagination-next {
		min-width: 2.625rem;
		height: 2.625rem;
	}
}

/* ═══════════════════════════════════════════════════════════
   16. RESPONSIVE — Mobile (≤ 599px)
   ═══════════════════════════════════════════════════════════ */

@media (max-width: 599px) {
	/* Single column grid */
	.sykim-archive-page .wp-block-post-template {
		grid-template-columns: 1fr !important;
		gap: 1rem !important;
	}

	/* 4:3 on mobile — better thumb-width readability */
	.sykim-archive-page .wp-block-post .wp-block-post-featured-image img {
		aspect-ratio: 4 / 3;
	}

	/* Card body: tighter padding on small screens */
	.sykim-card__body {
		padding: 1rem 1.125rem !important;
	}

	/* Card title: allow slightly smaller */
	.sykim-archive-page .wp-block-post .wp-block-post-title {
		font-size: 0.9375rem;
	}

	/* Archive / search hero: left-align on mobile */
	.sykim-archive-hero {
		text-align: left;
		padding: 2rem 1rem;
	}

	.sykim-archive-hero .wp-block-query-title {
		font-size: clamp(1.375rem, 6vw, 1.75rem) !important;
	}

	.sykim-archive-hero .wp-block-separator {
		margin-left: 0 !important;
	}

	.sykim-search-hero {
		text-align: left;
		padding: 1.75rem 1rem;
	}

	.sykim-blog-hero {
		padding: 2rem 1rem;
	}

	.sykim-search-empty {
		padding: 2.5rem 1rem 3rem;
	}

	/* Pagination: full touch target */
	.wp-block-query-pagination-numbers .page-numbers,
	.wp-block-query-pagination > a,
	.wp-block-query-pagination .wp-block-query-pagination-previous,
	.wp-block-query-pagination .wp-block-query-pagination-next {
		min-width: 2.75rem;
		height: 2.75rem;
		font-size: 0.875rem;
	}

	/* Author box: stack */
	.sykim-author-box {
		flex-direction: column;
		gap: 0.875rem;
		padding: 1.25rem;
	}

	/* Breadcrumb: allow wrapping */
	.sykim-breadcrumb {
		gap: 0.25rem 0.3125rem;
	}
}

/* ═══════════════════════════════════════════════════════════
   17. REDUCED MOTION
   ═══════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
	.sykim-archive-page .wp-block-post,
	.sykim-archive-page .wp-block-post .wp-block-post-featured-image img,
	.sykim-search-empty__cta,
	.wp-block-query-pagination-numbers .page-numbers,
	.wp-block-query-pagination > a {
		transition: none !important;
	}

	.sykim-archive-page .wp-block-post:hover {
		transform: none !important;
	}

	.sykim-archive-page .wp-block-post:hover .wp-block-post-featured-image img {
		transform: none !important;
	}

	.sykim-search-empty__cta:hover {
		transform: none !important;
	}
}
