.clp-library {
	--clp-columns: 3;
	--clp-gap: 24px;
	--clp-radius: 14px;
	--clp-border: #e5e7eb;
	--clp-text: #111827;
	--clp-muted: #6b7280;
	--clp-bg: #ffffff;
	--clp-soft: #f9fafb;
	color: var(--clp-text);
}

.clp-controls {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin: 0 0 24px;
}

.clp-control input,
.clp-control select {
	border: 1px solid var(--clp-border);
	border-radius: 10px;
	font: inherit;
	min-height: 42px;
	padding: 8px 12px;
}

.clp-control--search input {
	min-width: min(360px, 100%);
}

.clp-button,
.clp-card__button {
	align-items: center;
	background: var(--clp-text);
	border: 1px solid var(--clp-text);
	border-radius: 10px;
	color: #fff;
	display: inline-flex;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 42px;
	padding: 10px 16px;
	text-decoration: none;
}

.clp-button--secondary {
	background: transparent;
	color: var(--clp-text);
}

.clp-grid {
	display: grid;
	grid-template-columns: repeat(var(--clp-columns), minmax(0, 1fr));
	gap: var(--clp-gap);
}

.clp-card {
	background: var(--clp-bg);
	border: 1px solid var(--clp-border);
	border-radius: var(--clp-radius);
	overflow: hidden;
	transition: transform .18s ease, box-shadow .18s ease;
}

.clp-card:hover {
	box-shadow: 0 12px 28px rgba(17, 24, 39, .10);
	transform: translateY(-2px);
}

.clp-card__image {
	aspect-ratio: 16 / 9;
	background: var(--clp-soft);
	display: block;
	overflow: hidden;
}

.clp-card__image img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.clp-card__body {
	padding: 18px;
}

.clp-card__title {
	font-size: clamp(18px, 2vw, 22px);
	line-height: 1.2;
	margin: 0 0 10px;
}

.clp-card__title a {
	color: inherit;
	text-decoration: none;
}

.clp-card__excerpt {
	color: var(--clp-muted);
	font-size: 15px;
	line-height: 1.55;
	margin-bottom: 14px;
}

.clp-card__terms {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0 0 14px;
}

.clp-card__term {
	background: var(--clp-soft);
	border: 1px solid var(--clp-border);
	border-radius: 999px;
	color: var(--clp-muted);
	font-size: 12px;
	font-weight: 700;
	padding: 4px 9px;
}

.clp-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
	margin-top: 28px;
}

.clp-pagination .page-numbers {
	border: 1px solid var(--clp-border);
	border-radius: 8px;
	padding: 8px 12px;
	text-decoration: none;
}

.clp-pagination .current {
	background: var(--clp-text);
	color: #fff;
}

.clp-empty,
.clp-notice {
	background: var(--clp-soft);
	border: 1px solid var(--clp-border);
	border-radius: var(--clp-radius);
	padding: 18px;
}

@media (max-width: 900px) {
	.clp-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.clp-controls,
	.clp-control,
	.clp-control input,
	.clp-control select,
	.clp-button {
		width: 100%;
	}

	.clp-grid {
		grid-template-columns: 1fr;
	}
}

.clp-card__fields {
	border-top: 1px solid var(--clp-border);
	display: grid;
	gap: 8px;
	margin: 14px 0;
	padding-top: 12px;
}

.clp-card__field {
	display: grid;
	gap: 2px;
}

.clp-card__field dt {
	color: var(--clp-muted);
	font-size: 12px;
	font-weight: 700;
	margin: 0;
	text-transform: uppercase;
}

.clp-card__field dd {
	margin: 0;
}

.clp-playlists {
	display: grid;
	gap: var(--clp-gap, 24px);
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.clp-playlist-card {
	background: var(--clp-bg);
	border: 1px solid var(--clp-border);
	border-radius: var(--clp-radius);
	padding: 18px;
}

.clp-element--featured_image {
	margin: 0;
}

.clp-element:not(.clp-element--featured_image) {
	padding-left: 18px;
	padding-right: 18px;
}

.clp-element--title {
	padding-top: 18px;
}

.clp-element--button,
.clp-element--favorite_button,
.clp-element--playlist_button,
.clp-element--download_button,
.clp-element--back_button {
	padding-bottom: 18px;
}

.clp-action-button {
	background: transparent;
	border: 1px solid var(--clp-border);
	border-radius: 10px;
	cursor: pointer;
	font: inherit;
	font-weight: 700;
	min-height: 40px;
	padding: 9px 13px;
}

.clp-action-button.is-active {
	background: var(--clp-text);
	border-color: var(--clp-text);
	color: #fff;
}

.clp-action-button.is-loading {
	opacity: .6;
	pointer-events: none;
}

.clp-single {
	--clp-single-width: 860px;
	margin-left: auto;
	margin-right: auto;
	max-width: var(--clp-single-width);
}

.clp-single .clp-element {
	margin-bottom: 22px;
	padding-left: 0;
	padding-right: 0;
}

.clp-single__content {
	font-size: 17px;
	line-height: 1.7;
}

.clp-embed iframe {
	aspect-ratio: 16 / 9;
	height: auto;
	max-width: 100%;
	width: 100%;
}

.clp-card,
.clp-single {
	background: var(--clp-card-bg, var(--clp-bg));
	border-color: var(--clp-border-color, var(--clp-border));
	border-radius: var(--clp-card-radius, var(--clp-radius));
	box-shadow: var(--clp-card-shadow, none);
	color: var(--clp-card-text, var(--clp-text));
}

.clp-card {
	padding: var(--clp-card-padding, 0);
}

.clp-card__button,
.clp-button {
	background: var(--clp-button-bg, var(--clp-text));
	border-color: var(--clp-button-bg, var(--clp-text));
	color: var(--clp-button-text, #fff);
}

.clp-card__excerpt,
.clp-card__date,
.clp-card__author,
.clp-card__field dt {
	color: var(--clp-card-muted, var(--clp-muted));
}

.clp-layout-row {
	display: grid;
	gap: 18px;
	grid-template-columns: var(--clp-row-columns, minmax(0, 1fr));
	width: 100%;
}

.clp-layout-column {
	display: flex;
	flex-direction: column;
	min-width: 0;
	max-width: none !important;
}

.clp-layout-column .clp-element:last-child {
	margin-bottom: 0 !important;
}

.clp-element {
	box-sizing: border-box;
}

.clp-element--featured_image,
.clp-element--video_embed {
	padding-left: 0;
	padding-right: 0;
}

.clp-embed iframe,
.clp-embed video {
	aspect-ratio: 16 / 9;
	border: 0;
	display: block;
	height: auto;
	max-width: 100%;
	width: 100%;
}

.clp-badge {
	background: color-mix(in srgb, var(--clp-brand-color, #2563eb) 12%, white);
	border: 1px solid color-mix(in srgb, var(--clp-brand-color, #2563eb) 26%, white);
	border-radius: 999px;
	color: var(--clp-brand-color, #2563eb);
	display: inline-flex;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	padding: 7px 10px;
}

.clp-divider {
	border: 0;
	border-top: 1px solid var(--clp-border-color, var(--clp-border));
	margin: 0;
}

@media (max-width: 720px) {
	.clp-layout-row {
		grid-template-columns: minmax(0, 1fr) !important;
	}

	.clp-layout-column {
		max-width: none !important;
	}
}
