/* =========================================================
   InsuraBeat — Archive (category, tag, custom taxonomies, search…)
   Full-width navy cover header → cards grid → pagination → newsletter.
   ========================================================= */

.ib-archive { background: var(--ib-bg); }

/* ---------- Cover ---------- */
.ib-arch-cover {
	position: relative;
	width: 100%;
	min-height: clamp(300px, 38vh, 460px);
	background: linear-gradient(135deg, var(--ib-navy-900) 0%, var(--ib-navy-800) 60%, #0a182d 100%);
	color: #fff;
	overflow: hidden;
	isolation: isolate;
	display: flex;
	align-items: center;
}

.ib-arch-cover__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
}

/* Subtle radial pulses to suggest the "beat" brand without overpowering */
.ib-arch-cover__pulse {
	position: absolute;
	width: 540px;
	height: 540px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(230, 57, 70, .28) 0%, rgba(230, 57, 70, 0) 65%);
	top: -180px;
	right: -120px;
	filter: blur(8px);
}

.ib-arch-cover__pulse--b {
	width: 360px;
	height: 360px;
	background: radial-gradient(circle, rgba(0, 181, 160, .22) 0%, rgba(0, 181, 160, 0) 70%);
	top: auto;
	bottom: -160px;
	left: -100px;
	right: auto;
}

.ib-arch-cover__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: var(--ib-sp-7) var(--ib-sp-5);
	display: flex;
	flex-direction: column;
	gap: var(--ib-sp-3);
}

.ib-arch-cover__crumbs {
	font-family: var(--ib-font-sans);
	font-size: var(--ib-fs-xs);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, .7);
	margin-bottom: var(--ib-sp-2);
}

.ib-arch-cover__crumbs a {
	color: rgba(255, 255, 255, .85);
	transition: color var(--ib-dur) var(--ib-ease);
}

.ib-arch-cover__crumbs a:hover { color: var(--ib-accent); }
.ib-arch-cover__crumbs .sep { margin: 0 0.5rem; opacity: .5; }

.ib-arch-cover__eyebrow {
	margin: 0;
	font-family: var(--ib-font-sans);
	font-size: var(--ib-fs-xs);
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ib-accent);
}

.ib-arch-cover__title {
	margin: 0;
	font-family: var(--ib-font-serif);
	font-size: clamp(2rem, 4.4vw, var(--ib-fs-4xl));
	line-height: 1.08;
	letter-spacing: -0.02em;
	color: #fff;
	max-width: 18ch;
}

.ib-arch-cover__desc {
	font-family: var(--ib-font-sans);
	font-size: var(--ib-fs-md);
	line-height: 1.55;
	color: rgba(255, 255, 255, .82);
	max-width: 60ch;
}

.ib-arch-cover__desc p { margin: 0 0 0.6em; }
.ib-arch-cover__desc p:last-child { margin-bottom: 0; }

.ib-arch-cover__meta {
	display: flex;
	align-items: center;
	gap: var(--ib-sp-3);
	font-family: var(--ib-font-sans);
	font-size: var(--ib-fs-sm);
	color: rgba(255, 255, 255, .7);
	margin-top: var(--ib-sp-3);
	padding-top: var(--ib-sp-4);
	border-top: 1px solid rgba(255, 255, 255, .12);
}

.ib-arch-cover__count strong {
	font-family: var(--ib-font-serif);
	font-size: var(--ib-fs-lg);
	color: #fff;
	margin-right: 4px;
}

/* ---------- Grid ---------- */
.ib-archive__list {
	padding: var(--ib-sp-8) 0 var(--ib-sp-7);
	background: var(--ib-bg);
}

.ib-archive__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ib-sp-6) var(--ib-sp-5);
}

@media (max-width: 980px) {
	.ib-archive__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.ib-archive__grid { grid-template-columns: 1fr; }
}

/* Card titles upgrade slightly on archives — the card is the primary element */
.ib-archive__grid .ib-card__title {
	font-size: var(--ib-fs-md);
	line-height: 1.3;
}

/* ---------- Pagination ---------- */
.ib-pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--ib-sp-1);
	margin-top: var(--ib-sp-7);
	font-family: var(--ib-font-sans);
}

.ib-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--ib-sp-3);
	border-radius: var(--ib-radius);
	background: #fff;
	border: 1px solid var(--ib-line);
	color: var(--ib-navy-800);
	font-size: var(--ib-fs-sm);
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	justify-content: center;
	transition: all var(--ib-dur) var(--ib-ease);
}

.ib-pagination .page-numbers:hover {
	background: var(--ib-navy-900);
	border-color: var(--ib-navy-900);
	color: #fff;
}

.ib-pagination .page-numbers.current {
	background: var(--ib-accent);
	border-color: var(--ib-accent);
	color: #fff;
}

.ib-pagination .page-numbers.dots {
	background: transparent;
	border: 0;
	color: var(--ib-ink-soft);
	min-width: 24px;
	padding: 0;
}

.ib-pagination .page-numbers.prev,
.ib-pagination .page-numbers.next {
	padding: 0 var(--ib-sp-4);
}

/* ---------- Empty state ---------- */
.ib-archive__empty {
	text-align: center;
	padding: var(--ib-sp-8) var(--ib-sp-5);
	background: var(--ib-bg-alt);
	border-radius: var(--ib-radius-lg);
}

.ib-archive__empty h2 {
	font-family: var(--ib-font-serif);
	font-size: var(--ib-fs-xl);
	color: var(--ib-navy-900);
	margin: 0 0 var(--ib-sp-3);
}

.ib-archive__empty p {
	color: var(--ib-ink-muted);
	font-size: var(--ib-fs-md);
	margin: 0 0 var(--ib-sp-5);
	max-width: 50ch;
	margin-left: auto;
	margin-right: auto;
}

/* Strip GP container constraints on archives — covered by global rules in theme.css already,
   but we make sure our archive-specific elements aren't reverted by any leftover setting. */
body.archive .inside-article,
body.archive article.post,
body.search .inside-article,
body.search article.post {
	background: transparent;
	padding: 0;
	box-shadow: none;
}

body.archive .ib-arch-cover,
body.search .ib-arch-cover {
	width: 100%;
	max-width: 100%;
}

/* =========================================================
   Search results — extends archive cover with a refine form,
   highlighted matches, and a rich empty state.
   ========================================================= */

.ib-search-cover .ib-arch-cover__title { max-width: 30ch; }

.ib-search-cover__query {
	display: inline-block;
	color: var(--ib-accent);
	font-style: italic;
}

.ib-search-cover__form {
	display: flex;
	align-items: center;
	gap: var(--ib-sp-2);
	background: rgba(255, 255, 255, .08);
	border: 1px solid rgba(255, 255, 255, .2);
	border-radius: var(--ib-radius);
	padding: var(--ib-sp-2) var(--ib-sp-2) var(--ib-sp-2) var(--ib-sp-4);
	margin-top: var(--ib-sp-3);
	max-width: 720px;
	transition: border-color var(--ib-dur) var(--ib-ease), background var(--ib-dur) var(--ib-ease);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
}

.ib-search-cover__form:focus-within {
	border-color: var(--ib-accent);
	background: rgba(255, 255, 255, .14);
}

.ib-search-cover__icon {
	color: rgba(255, 255, 255, .7);
	flex-shrink: 0;
}

.ib-search-cover__form:focus-within .ib-search-cover__icon { color: var(--ib-accent); }

.ib-search-cover__input {
	flex: 1;
	background: transparent;
	border: 0;
	padding: var(--ib-sp-3) 0;
	font-family: var(--ib-font-serif);
	font-size: var(--ib-fs-md);
	color: #fff;
	outline: none;
	min-width: 0;
}

.ib-search-cover__input::placeholder {
	color: rgba(255, 255, 255, .55);
	font-style: italic;
}

.ib-search-cover__submit {
	background: var(--ib-accent);
	color: #fff;
	border: 0;
	padding: 0 var(--ib-sp-5);
	height: 42px;
	border-radius: calc(var(--ib-radius) - 2px);
	font-family: var(--ib-font-sans);
	font-weight: 600;
	font-size: var(--ib-fs-sm);
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background var(--ib-dur) var(--ib-ease);
	flex-shrink: 0;
}

.ib-search-cover__submit:hover { background: var(--ib-accent-dark); }

/* Highlighted matches inside cards */
.ib-card__title mark,
.ib-card__excerpt mark {
	background: rgba(230, 57, 70, 0.15);
	color: var(--ib-accent-dark);
	padding: 0 2px;
	border-radius: 2px;
	font-weight: 600;
}

/* ---------- Empty state ---------- */
.ib-search-empty {
	background: var(--ib-bg);
	padding: var(--ib-sp-9) 0 var(--ib-sp-7);
}

.ib-search-empty .ib-container { max-width: 1100px; }

.ib-search-empty__title {
	font-family: var(--ib-font-serif);
	font-size: clamp(1.5rem, 2.6vw, var(--ib-fs-2xl));
	color: var(--ib-navy-900);
	margin: 0 0 var(--ib-sp-3);
	line-height: 1.2;
	max-width: 30ch;
}

.ib-search-empty__lead {
	font-family: var(--ib-font-sans);
	font-size: var(--ib-fs-md);
	color: var(--ib-ink-muted);
	line-height: 1.55;
	margin: 0 0 var(--ib-sp-5);
	max-width: 60ch;
}

.ib-search-empty__chips {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ib-sp-2);
	margin-bottom: var(--ib-sp-8);
}

.ib-search-empty__chips .ib-tag {
	font-size: var(--ib-fs-sm);
	padding: 0.4rem 0.9rem;
	background: var(--ib-bg-alt);
	color: var(--ib-navy-800);
	border: 1px solid var(--ib-line);
	transition: all var(--ib-dur) var(--ib-ease);
}

.ib-search-empty__chips .ib-tag:hover {
	background: var(--ib-navy-900);
	color: #fff;
	border-color: var(--ib-navy-900);
}

.ib-search-empty__latest {
	margin-top: var(--ib-sp-7);
	padding-top: var(--ib-sp-7);
	border-top: 1px solid var(--ib-line);
}

.ib-search-empty__latest-title {
	font-family: var(--ib-font-serif);
	font-size: var(--ib-fs-xl);
	color: var(--ib-navy-900);
	margin: 0 0 var(--ib-sp-5);
	display: flex;
	align-items: baseline;
	gap: var(--ib-sp-3);
}

.ib-search-empty__latest-title::before {
	content: "";
	display: inline-block;
	width: 4px;
	height: 22px;
	background: var(--ib-accent);
	border-radius: 2px;
	transform: translateY(3px);
}

@media (max-width: 760px) {
	.ib-search-cover__form { flex-wrap: wrap; padding: var(--ib-sp-2); }
	.ib-search-cover__input { width: 100%; padding: var(--ib-sp-2); }
	.ib-search-cover__submit { width: 100%; }
}
