/**
 * KWC Card Grid — frontend styles.
 *
 * Defaults to the KWC brand tokens defined in the theme (--primary-font,
 * --brand-color-purple, --rps-color-gray-*, etc.). Every token has a
 * non-brand fallback so the block still works on pages where those
 * variables aren't loaded.
 *
 * All visual properties are CSS custom properties on .kwc-cg-wrap so
 * per-instance overrides (set as inline style by the render callback)
 * override the defaults cleanly.
 */

.kwc-cg-wrap {
	/* Layout */
	--kwc-cg-min-col: 200px;
	--kwc-cg-gap: 0.5rem;
	--kwc-cg-radius: 6px;

	/* Typography (overridden per-instance via inline style) */
	--kwc-cg-name-size: 15px;
	--kwc-cg-desc-size: 13px;
	--kwc-cg-name-family: var(--primary-font, system-ui, sans-serif);
	--kwc-cg-desc-family: var(--secondary-font, system-ui, sans-serif);
	--kwc-cg-name-weight: 600;

	/* Colors — defaults map to KWC brand tokens with fallbacks */
	--kwc-cg-border-color: rgba(var(--brand-color-very-light-gray, 216, 216, 216), 1);
	--kwc-cg-border-color-hover: rgba(var(--brand-color-light-gray, 184, 184, 184), 1);
	--kwc-cg-card-bg: rgb(var(--brand-color-white, 255, 255, 255));
	--kwc-cg-text-color: rgb(var(--brand-color-extremely-dark-gray, 16, 16, 16));
	--kwc-cg-muted: rgb(var(--brand-color-dark-gray, 104, 104, 104));
	--kwc-cg-pill-bg: rgb(var(--brand-color-white, 255, 255, 255));
	--kwc-cg-pill-active-bg: rgb(var(--brand-color-purple, 75, 42, 171));
	--kwc-cg-pill-active-color: rgb(var(--brand-color-white, 255, 255, 255));
	--kwc-cg-focus-color: rgb(var(--brand-color-purple, 75, 42, 171));

	margin: 1.5rem 0;
	color: var(--kwc-cg-text-color);
}

/* ===== Controls (search + pills) ===== */

.kwc-cg-controls {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}

.kwc-cg-search-wrap {
	display: block;
}

.kwc-cg-search {
	width: 100%;
	max-width: 28rem;
	padding: 0.5rem 0.75rem;
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.95rem;
	color: var(--kwc-cg-text-color);
	border: 1px solid var(--kwc-cg-border-color);
	border-radius: var(--kwc-cg-radius);
	background: var(--kwc-cg-card-bg);
	box-sizing: border-box;
}

.kwc-cg-search:focus {
	outline: 2px solid var(--kwc-cg-focus-color);
	outline-offset: 2px;
}

.kwc-cg-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.kwc-cg-pill {
	display: inline-block;
	padding: 0.55rem 1.15rem;
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1.4;
	color: var(--kwc-cg-pill-active-bg);
	background: var(--kwc-cg-card-bg);
	border: 2px solid var(--kwc-cg-border-color);
	border-radius: 999px;
	cursor: pointer;
	transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
	white-space: nowrap;
}

.kwc-cg-pill:hover {
	border-color: var(--kwc-cg-pill-active-bg);
}

.kwc-cg-pill:focus-visible {
	outline: 2px solid var(--kwc-cg-focus-color);
	outline-offset: 2px;
}

.kwc-cg-pill.is-active {
	background: var(--kwc-cg-pill-active-bg);
	color: var(--kwc-cg-pill-active-color);
	border-color: var(--kwc-cg-pill-active-bg);
}

/* ===== Count message ===== */

.kwc-cg-count {
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.8125rem;
	color: var(--kwc-cg-muted);
	margin: 0 0 0.5rem;
}

/* ===== Active category description ===== */

.kwc-cg-cat-descriptions {
	margin: 0 0 1rem;
}

.kwc-cg-cat-description {
	margin: 0;
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--kwc-cg-text-color);
	max-width: 65ch;
}

.kwc-cg-cat-description[hidden] { display: none; }

/* ===== Card grid ===== */

.kwc-cg-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(var(--kwc-cg-min-col), 1fr));
	gap: var(--kwc-cg-gap);
}

.kwc-cg-card {
	display: block;
	padding: 0.625rem 0.75rem;
	background: var(--kwc-cg-card-bg);
	border: 1px solid var(--kwc-cg-border-color);
	border-radius: var(--kwc-cg-radius);
	text-decoration: none;
	color: var(--kwc-cg-text-color);
	transition: border-color 0.15s ease;
}

.kwc-cg-card:hover {
	border-color: var(--kwc-cg-border-color-hover);
}

a.kwc-cg-card:focus-visible {
	outline: 2px solid var(--kwc-cg-focus-color);
	outline-offset: 2px;
}

.kwc-cg-card[hidden] {
	display: none;
}

.kwc-cg-card__name {
	margin: 0 0 0.2rem;
	font-family: var(--kwc-cg-name-family);
	font-weight: var(--kwc-cg-name-weight);
	font-size: var(--kwc-cg-name-size);
	line-height: 1.3;
	color: var(--kwc-cg-name-color, var(--kwc-cg-text-color));
}

.kwc-cg-card__desc {
	margin: 0;
	font-family: var(--kwc-cg-desc-family);
	font-size: var(--kwc-cg-desc-size);
	line-height: 1.45;
	color: var(--kwc-cg-muted);
}

/* ===== Compact density ===== */
/*
 * In compact mode, descriptions are hidden at rest and revealed on hover
 * (or focus, for keyboard users). Cards have tighter padding and a smaller
 * default minimum column width to fit more per row.
 */

.kwc-cg-density-compact {
	--kwc-cg-min-col: 160px;
	--kwc-cg-gap: 4px;
}

.kwc-cg-density-compact .kwc-cg-card {
	padding: 0.4rem 0.6rem;
	position: relative;
}

.kwc-cg-density-compact .kwc-cg-card__name {
	margin: 0;
}

.kwc-cg-density-compact .kwc-cg-card__desc {
	max-height: 0;
	margin: 0;
	overflow: hidden;
	transition: max-height 0.2s ease, margin-top 0.2s ease;
}

.kwc-cg-density-compact .kwc-cg-card:hover,
.kwc-cg-density-compact .kwc-cg-card:focus,
.kwc-cg-density-compact .kwc-cg-card:focus-within {
	border-color: var(--kwc-cg-pill-active-bg);
}

.kwc-cg-density-compact .kwc-cg-card:hover .kwc-cg-card__desc,
.kwc-cg-density-compact .kwc-cg-card:focus .kwc-cg-card__desc,
.kwc-cg-density-compact .kwc-cg-card:focus-within .kwc-cg-card__desc {
	max-height: 8rem;
	margin-top: 0.25rem;
}

/* Tap-to-reveal helper on touch devices */
.kwc-cg-density-compact .kwc-cg-card.is-touched .kwc-cg-card__desc {
	max-height: 8rem;
	margin-top: 0.25rem;
}

/* ===== Picker panel (default view: "Show category picker first") ===== */

.kwc-cg-picker {
	margin: 1rem 0;
}

.kwc-cg-picker__heading {
	margin: 0 0 0.25rem;
	font-family: var(--kwc-cg-name-family);
	font-weight: 500;
	font-size: 1.25rem;
	line-height: 1.3;
	color: var(--kwc-cg-text-color);
}

.kwc-cg-picker__subheading {
	margin: 0 0 1rem;
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.95rem;
	line-height: 1.45;
	color: var(--kwc-cg-text-color);
}

.kwc-cg-picker__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 8px;
}

.kwc-cg-picker__card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 4px;
	padding: 1rem 1.1rem;
	background: var(--kwc-cg-card-bg);
	border: 1px solid var(--kwc-cg-border-color);
	border-radius: var(--kwc-cg-radius);
	cursor: pointer;
	font-family: inherit;
	text-align: left;
	color: var(--kwc-cg-text-color);
	transition: border-color 0.15s ease, background-color 0.15s ease, transform 0.05s ease;
}

.kwc-cg-picker__card:hover {
	border-color: var(--kwc-cg-pill-active-bg);
}

.kwc-cg-picker__card:focus-visible {
	outline: 2px solid var(--kwc-cg-pill-active-bg);
	outline-offset: 2px;
}

.kwc-cg-picker__card:active {
	transform: scale( 0.99 );
}

.kwc-cg-picker__card-label {
	font-family: var(--kwc-cg-name-family);
	font-weight: var(--kwc-cg-name-weight);
	font-size: var(--kwc-cg-name-size);
	line-height: 1.3;
}

.kwc-cg-picker__card-count {
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.8125rem;
	color: var(--kwc-cg-muted);
}

/* ===== Empty + admin notices ===== */

.kwc-cg-empty {
	margin: 0.75rem 0;
	padding: 0.75rem 0.9rem;
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.875rem;
	color: var(--kwc-cg-muted);
	border: 1px dashed var(--kwc-cg-border-color);
	border-radius: var(--kwc-cg-radius);
	text-align: center;
}

.kwc-cg-empty-notice {
	margin: 1rem 0;
	padding: 0.75rem 0.9rem;
	font-family: var(--kwc-cg-desc-family);
	font-size: 0.875rem;
	color: var(--kwc-cg-muted);
	border: 1px dashed var(--kwc-cg-border-color);
	border-radius: var(--kwc-cg-radius);
	background: rgba(var(--brand-color-extremely-light-gray, 245, 245, 245), 0.5);
}
