/**
 * Template Library — archive and single (intranet).
 *
 * @package Campus
 */

.cp-template-lib {
	--cp-tpl-text: #0f172a;
	--cp-tpl-muted: #64748b;
	--cp-tpl-muted2: #94a3b8;
	--cp-tpl-border: #e2e8f0;
	--cp-tpl-border2: #f1f5f9;
	--cp-tpl-surface: #ffffff;
	--cp-tpl-thead: #f8fafc;
	--cp-tpl-link: #1d4ed8;
	--cp-tpl-badge-bg: #eff6ff;
	--cp-tpl-badge-text: #1d4ed8;
	--cp-tpl-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 16px 48px;
}

@media (prefers-reduced-motion: reduce) {
	.cp-template-lib a,
	.cp-template-lib .campus-btn {
		transition: none !important;
	}
}

.cp-template-lib-header {
	margin-bottom: 24px;
	padding-bottom: 8px;
	background: linear-gradient(180deg, rgba(248, 250, 252, 0.95) 0%, transparent 100%);
	border-radius: 0 0 16px 16px;
}

.cp-template-lib-title {
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 700;
	color: var(--cp-tpl-text);
	margin: 0 0 8px;
}

.cp-template-lib-intro {
	color: var(--cp-tpl-muted);
	margin: 0 0 20px;
	line-height: 1.5;
}

.cp-template-lib-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: flex-end;
	margin-bottom: 8px;
}

.cp-template-lib-search input[type='search'] {
	min-width: 200px;
	padding: 10px 14px;
	border: 1px solid var(--cp-tpl-border);
	border-radius: 8px;
	font-size: 15px;
	background: var(--cp-tpl-surface);
	color: var(--cp-tpl-text);
}

.cp-template-lib-filter select {
	padding: 10px 14px;
	border: 1px solid var(--cp-tpl-border);
	border-radius: 8px;
	font-size: 14px;
	min-width: 180px;
	background: var(--cp-tpl-surface);
	color: var(--cp-tpl-text);
}

.cp-template-lib-count {
	font-size: 14px;
	color: var(--cp-tpl-muted);
	margin: 0 0 16px;
}

.cp-template-lib-table-wrap {
	overflow-x: auto;
	border: 1px solid var(--cp-tpl-border);
	border-radius: 12px;
	background: var(--cp-tpl-surface);
	box-shadow: var(--cp-tpl-shadow);
}

.cp-template-lib-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}

.cp-template-lib-table thead th {
	text-align: left;
	padding: 12px 16px;
	background: var(--cp-tpl-thead);
	color: #475569;
	font-weight: 600;
	border-bottom: 1px solid var(--cp-tpl-border);
}

.cp-template-lib-table tbody td {
	padding: 14px 16px;
	border-bottom: 1px solid var(--cp-tpl-border2);
	vertical-align: middle;
}

.cp-template-lib-table tbody tr:last-child td {
	border-bottom: none;
}

.cp-template-lib-col-icon {
	width: 40px;
	text-align: center;
}

.cp-template-lib-title-link {
	color: var(--cp-tpl-link);
	font-weight: 600;
	text-decoration: none;
	transition: color 0.15s ease;
}

.cp-template-lib-title-link:hover {
	text-decoration: underline;
}

.cp-template-lib-actions {
	text-align: right;
	white-space: nowrap;
}

.campus-btn-sm {
	padding: 6px 12px;
	font-size: 13px;
}

.cp-template-lib-no-file {
	font-size: 13px;
	color: var(--cp-tpl-muted2);
}

.cp-template-lib-pagination {
	margin-top: 24px;
}

/* Single */
.cp-template-lib-breadcrumb {
	font-size: 14px;
	margin-bottom: 16px;
	color: var(--cp-tpl-muted);
}

.cp-template-lib-breadcrumb a {
	color: var(--cp-tpl-link);
	text-decoration: none;
}

.cp-template-lib-breadcrumb a:hover {
	text-decoration: underline;
}

.cp-template-lib-bc-sep {
	margin: 0 8px;
	color: var(--cp-tpl-border);
}

.cp-template-lib-single-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 24px;
}

@media (min-width: 900px) {
	.cp-template-lib-single-grid {
		grid-template-columns: 1fr 320px;
		align-items: start;
	}
}

.cp-template-lib-single-title {
	font-size: clamp(1.35rem, 3vw, 1.75rem);
	margin: 0 0 8px;
	color: var(--cp-tpl-text);
}

.cp-template-lib-version-badge {
	display: inline-block;
	margin: 0 0 16px;
	padding: 4px 10px;
	background: var(--cp-tpl-badge-bg);
	color: var(--cp-tpl-badge-text);
	border-radius: 999px;
	font-size: 13px;
	font-weight: 600;
}

.cp-template-lib-body {
	margin-bottom: 16px;
}

.cp-template-lib-updated {
	font-size: 13px;
	color: var(--cp-tpl-muted2);
	margin: 0;
}

.cp-template-lib-card {
	padding: 20px;
}

.cp-template-lib-card-title {
	margin: 0 0 16px;
	font-size: 16px;
	color: var(--cp-tpl-text);
}

.cp-template-lib-file-row {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 16px;
}

.cp-template-lib-file-row .dashicons {
	font-size: 28px;
	width: 28px;
	height: 28px;
	color: var(--cp-tpl-muted);
}

.cp-template-lib-file-meta {
	display: block;
	font-size: 12px;
	color: var(--cp-tpl-muted2);
	margin-top: 4px;
}

.cp-template-lib-dl {
	width: 100%;
	text-align: center;
	justify-content: center;
}

.cp-template-lib-no-dl {
	color: var(--cp-tpl-muted);
	font-size: 14px;
	margin: 0;
}

.cp-template-lib-depts {
	margin-top: 20px;
	padding-top: 16px;
	border-top: 1px solid var(--cp-tpl-border2);
}

.cp-template-lib-depts h3 {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--cp-tpl-muted);
	margin: 0 0 8px;
}

.cp-template-lib-dept-list {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.cp-template-lib-not-found {
	padding: 48px 16px;
	text-align: center;
	color: var(--cp-tpl-muted);
}

/* Mobile: stack table */
@media (max-width: 640px) {
	.cp-template-lib-table thead {
		display: none;
	}

	.cp-template-lib-table tbody tr {
		display: block;
		border-bottom: 1px solid var(--cp-tpl-border2);
		padding: 12px 0;
	}

	.cp-template-lib-table tbody td {
		display: flex;
		justify-content: space-between;
		gap: 12px;
		padding: 6px 16px;
		border: none;
	}

	.cp-template-lib-table tbody td::before {
		content: attr(data-label);
		font-weight: 600;
		color: var(--cp-tpl-muted);
		flex-shrink: 0;
	}

	.cp-template-lib-col-icon {
		display: none;
	}
}
