/* ==========================================================
 * Importer Book — Category & Tag Archive Layout
 * Scope: body.ib-cat-layout.archive (category + tag)
 * Modes:
 *   - .ib-cat-list  = horizontal list (1 per row)
 *   - .ib-cat-grid.ib-cat-cols-2/3/4 = card grid
 * Theme: GeneratePress
 * ======================================================= */

/* Shared: centre the main column a bit tighter */
body.ib-cat-layout.archive .site-main {
	max-width: 1120px;
	margin-left: auto;
	margin-right: auto;
}

/* Reset some default archive spacing */
body.ib-cat-layout.archive article.post {
	padding: 0;
	margin-bottom: 26px;
}

/* ==============================================
 * LIST MODE (default) — big horizontal card
 * =========================================== */
body.ib-cat-layout.ib-cat-list.archive article.post {
	margin-bottom: 26px;
}

/* Card shell: use CSS grid inside each article */
body.ib-cat-layout.ib-cat-list.archive .inside-article {
	display: grid;
	grid-template-columns: minmax(0, 34%) minmax(0, 1fr);
	column-gap: 24px;
	align-items: flex-start;
	padding: 20px 24px;
	background: #ffffff;
	border-radius: 18px;
	border: 1px solid rgba(226, 232, 240, 0.9);
	box-shadow: 0 10px 30px rgba(15, 23, 42, 0.12);
}

/* Remove default bottom borders / padding GP adds */
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-header,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-summary,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-meta,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-footer {
	border: 0;
	padding-left: 0;
	padding-right: 0;
}

/* Image on the left, spanning full height of the card */
body.ib-cat-layout.ib-cat-list.archive .inside-article .post-image {
	grid-row: 1 / span 3;
	grid-column: 1 / 2;
	margin: 0;
	border-radius: 16px;
	overflow: hidden;
	background: #f3f4f6;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .post-image a,
body.ib-cat-layout.ib-cat-list.archive .inside-article .post-image img {
	display: block;
	width: 100%;
	height: 100%;
	border-radius: inherit;
	object-fit: cover;
}

/* Text content in the right column */
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-header,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-summary,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-footer,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-meta {
	grid-column: 2 / 3;
}

/* Title */
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-header {
	margin-top: 4px;
	margin-bottom: 6px;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-title {
	font-size: 1.1rem;
	line-height: 1.35;
	margin: 0 0 4px;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-title a {
	color: #111827;
	text-decoration: none;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-title a:hover,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-title a:focus-visible {
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Meta row (date + author) */
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #6b7280;
	margin-bottom: 8px;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-meta a {
	color: inherit;
	text-decoration: none;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-meta a:hover,
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-meta a:focus-visible {
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Excerpt */
body.ib-cat-layout.ib-cat-list.archive .inside-article .entry-summary {
	font-size: 0.93rem;
	line-height: 1.6;
	color: #4b5563;
	margin-bottom: 8px;
}

/* "Read more" as pill button if present */
body.ib-cat-layout.ib-cat-list.archive .inside-article .read-more,
body.ib-cat-layout.ib-cat-list.archive .inside-article .read-more a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .read-more a {
	padding: 6px 16px;
	border-radius: 999px;
	background: #111827;
	color: #ffffff;
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
}

body.ib-cat-layout.ib-cat-list.archive .inside-article .read-more a:hover,
body.ib-cat-layout.ib-cat-list.archive .inside-article .read-more a:focus-visible {
	background: #0f172a;
	color: #ffffff;
}

/* Mobile: stack image above text */
@media (max-width: 768px) {
	body.ib-cat-layout.ib-cat-list.archive .inside-article {
		grid-template-columns: 1fr;
		row-gap: 14px;
		padding: 16px 16px 18px;
	}

	body.ib-cat-layout.ib-cat-list.archive .inside-article .post-image {
		grid-row: 1 / 2;
		grid-column: 1 / 2;
		max-width: 100%;
	}
}

/* ==============================================
 * GRID MODE — cards in 2 / 3 / 4 columns
 * =========================================== */

body.ib-cat-layout.ib-cat-grid.archive .site-main {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr)); /* default, overridden by cols below */
	gap: 24px;
}

/* Columns: 2 / 3 / 4 based on body class from PHP */
body.ib-cat-layout.ib-cat-grid.ib-cat-cols-2.archive .site-main {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.ib-cat-layout.ib-cat-grid.ib-cat-cols-3.archive .site-main {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.ib-cat-layout.ib-cat-grid.ib-cat-cols-4.archive .site-main {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* Cards: simple vertical layout inside each post */
body.ib-cat-layout.ib-cat-grid.archive article.post {
	margin: 0; /* grid handles spacing */
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 16px 16px 18px;
	background: #ffffff;
	border-radius: 16px;
	border: 1px solid rgba(226, 232, 240, 0.9);
	box-shadow: 0 8px 24px rgba(15, 23, 42, 0.10);
}

/* Thumbnail on top */
body.ib-cat-layout.ib-cat-grid.archive .inside-article .post-image {
	margin: 0 0 10px;
	border-radius: 14px;
	overflow: hidden;
	background: #f3f4f6;
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article .post-image a,
body.ib-cat-layout.ib-cat-grid.archive .inside-article .post-image img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: inherit;
}

/* Title & meta */
body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-header {
	margin: 0 0 6px;
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-title {
	font-size: 1rem;
	line-height: 1.35;
	margin: 0 0 4px;
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-title a {
	color: #111827;
	text-decoration: none;
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-title a:hover,
body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-title a:focus-visible {
	text-decoration: underline;
	text-underline-offset: 2px;
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-meta {
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #6b7280;
	margin-bottom: 6px;
}

/* Excerpt + footer */
body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-summary {
	font-size: 0.9rem;
	line-height: 1.5;
	color: #4b5563;
	margin-bottom: 8px;
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article .entry-footer {
	margin-top: auto;
}

/* Read more (same style as list) */
body.ib-cat-layout.ib-cat-grid.archive .inside-article .read-more a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 14px;
	border-radius: 999px;
	background: #111827;
	color: #ffffff;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
}

body.ib-cat-layout.ib-cat-grid.archive .inside-article .read-more a:hover,
body.ib-cat-layout.ib-cat-grid.archive .inside-article .read-more a:focus-visible {
	background: #0f172a;
	color: #ffffff;
}

/* Mobile: grid collapses to single column */
@media (max-width: 768px) {
	body.ib-cat-layout.ib-cat-grid.archive .site-main {
		grid-template-columns: 1fr !important;
	}
}

/* ==========================================================
 * Archive header full width above grid (category + tag)
 * ======================================================= */

/* Archive header should span full width in grid layout (category, tag, author) */
body.ib-cat-layout.ib-cat-grid.archive .site-main > .page-header {
	grid-column: 1 / -1;
	margin-bottom: 24px;
}

/* Author subject box (author archives) — span full width above grid cards */
body.ib-cat-layout.ib-cat-grid.archive.author .site-main > .author-info,
body.ib-cat-layout.ib-cat-grid.archive.author .site-main > .author-box {
	grid-column: 1 / -1;
	margin-bottom: 24px;
}


/* ==========================================================
 * Hide taxonomy lists (categories + tags) under each card
 * (keep top date/author meta)
 * ======================================================= */

/* 1) Any classic footer meta block under the card */
body.ib-cat-layout.archive .inside-article .entry-footer,
body.ib-cat-layout.archive .inside-article .post-taxonomy {
	display: none;
}

/* 2) If a second .entry-meta appears AFTER the excerpt,
      hide that one (the "posted in / tagged" block). */
body.ib-cat-layout.archive .inside-article .entry-summary + .entry-meta {
	display: none;
}

/* 3) Safety: directly target typical GP taxonomy link wrappers. */
body.ib-cat-layout.archive .inside-article .cat-links,
body.ib-cat-layout.archive .inside-article .tags-links {
	display: none;
}

/* ==========================================================
 * Archive pagination (category + tag) — pill style
 * ======================================================= */

body.ib-cat-layout.archive .ib-archive-pagination {
	margin: 28px auto 10px;
	text-align: center;
}

body.ib-cat-layout.archive .ib-archive-pagination .nav-links {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

/* Base button style for all numbers + prev/next */
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 34px;
	padding: 0 14px;
	border-radius: 999px;
	border: 1px solid #e5e7eb;
	background: #ffffff;
	color: #2563eb; /* link blue like screenshot */
	font-size: 0.9rem;
	font-weight: 500;
	text-decoration: none;
	transition:
		background-color 120ms ease-out,
		color 120ms ease-out,
		border-color 120ms ease-out,
		box-shadow 120ms ease-out;
}

/* Current page — filled pill (pink/magenta) */
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers.current {
	background: #d81b60;           /* magenta tone */
	border-color: #d81b60;
	color: #ffffff;
	box-shadow: 0 0 0 1px rgba(216, 27, 96, 0.35);
}

/* Hover / focus for non-current buttons */
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers:not(.current):hover,
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers:not(.current):focus-visible {
	background: #f3f4f6;
	border-color: #d1d5db;
	color: #1f2937;
}

/* Keep current page text white on hover */
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers.current:hover,
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers.current:focus-visible {
	color: #ffffff;
}

/* Smaller width for « Previous / Next » so they look like the screenshot */
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers.prev,
body.ib-cat-layout.archive .ib-archive-pagination .page-numbers.next {
	min-width: 68px;
}

/* ==========================================================
 * Archive subject header (Category + Tag)
 * ======================================================= */

body.ib-cat-layout.archive .site-main > .page-header {
	max-width: 1120px;
	margin: 0 auto 26px;
	padding: 26px 32px;
	border-radius: 18px;
	background:
		radial-gradient(140% 140% at 0% 0%,
			rgba(249, 115, 22, 0.10),
			rgba(255, 255, 255, 1));
	border: 1px solid #e5e7eb;
	box-shadow: 0 18px 40px rgba(15, 23, 42, 0.10);
}

body.ib-cat-layout.archive .site-main > .page-header .page-title {
	margin: 0;
	font-size: clamp(1.9rem, 1.6rem + 1vw, 2.4rem);
	font-weight: 800;
	letter-spacing: 0.02em;
	color: #111827;
}

body.ib-cat-layout.archive .site-main > .page-header .archive-description {
	margin-top: 6px;
	max-width: 640px;
	font-size: 0.95rem;
	color: #4b5563;
}

/* ==========================================================
 * Card hover — warm highlight on archives
 * ======================================================= */

/* Smooth hover for the whole card */
body.ib-cat-layout.archive .inside-article {
	transition:
		box-shadow 160ms ease-out,
		transform 160ms ease-out,
		border-color 160ms ease-out,
		background-color 160ms ease-out;
}

body.ib-cat-layout.archive .inside-article:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 40px rgba(15, 23, 42, 0.18);
	border-color: rgba(249, 115, 22, 0.45);
	background-color: #ffffff;
}

/* Thumbnail container: keep corners rounded + hide overflow */
body.ib-cat-layout.archive .inside-article .post-image,
body.ib-cat-layout.archive .inside-article .featured-image {
	overflow: hidden;
	border-radius: 18px;
}

/* Subtle zoom + warmth on thumbnail when hovering */
body.ib-cat-layout.archive .inside-article .post-image img,
body.ib-cat-layout.archive .inside-article .featured-image img {
	transition:
		transform 180ms ease-out,
		filter 180ms ease-out;
}

body.ib-cat-layout.archive .inside-article:hover .post-image img,
body.ib-cat-layout.archive .inside-article:hover .featured-image img {
	transform: scale(1.04);
	filter: brightness(1.05) saturate(1.03);
}
