.ced-cms { background: var(--wp--preset--color--ink); position: relative; }
.ced-cms::before {
	content: ""; position: absolute;
	inset: 0;
	background: radial-gradient(60% 50% at 50% 0%, rgba(203, 108, 230, 0.08) 0%, transparent 60%);
	pointer-events: none;
}
.ced-cms__head {
	display: grid;
	gap: var(--wp--preset--spacing--sm);
	max-width: var(--page-max);
	margin: 0 auto var(--wp--preset--spacing--lg);
	position: relative;
}
.ced-cms__title {
	font-size: clamp(2.25rem, 5vw, 4.75rem);
	font-weight: 500;
	line-height: 1.04;
	letter-spacing: -0.04em;
	margin: 0;
	color: var(--wp--preset--color--paper);
	max-width: 22ch;
}
.ced-cms__lede {
	color: var(--wp--preset--color--mist);
	font-size: var(--wp--preset--font-size--lg);
	max-width: 60ch;
	margin: 0;
	line-height: 1.45;
}

/* --- Bento grid: 4 categories, asymmetric on desktop --------------- */
.ced-cms__bento {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1px;
	background: var(--ced-line-08);
	border: 1px solid var(--ced-line-08);
	border-radius: var(--wp--custom--radius--lg);
	overflow: clip;
	position: relative;
}
@media (min-width: 900px) {
	.ced-cms__bento {
		grid-template-columns: 1.2fr 1fr;
		grid-auto-rows: minmax(420px, auto);
	}
	.ced-cms__bento > .ced-cms__cat:nth-child(1) { grid-row: span 1; }
	.ced-cms__bento > .ced-cms__cat:nth-child(2) { grid-row: span 1; }
	.ced-cms__bento > .ced-cms__cat:nth-child(3) { grid-row: span 1; }
	.ced-cms__bento > .ced-cms__cat:nth-child(4) { grid-row: span 1; }
}

.ced-cms__cat {
	background: var(--wp--preset--color--graphite);
	padding: clamp(1.75rem, 3vw, 2.75rem);
	display: grid;
	gap: 1.5rem;
	position: relative;
	overflow: hidden;
}
/* Color-keyed category panels — each with its own accent + tint */
.ced-cms__cat {
	--cat-accent: var(--wp--preset--color--lime);
	--cat-tint:   rgba(203, 108, 230, 0.08);
}
.ced-cms__cat[data-slug="visual"] {
	--cat-accent: var(--wp--preset--color--sunset);
	--cat-tint:   rgba(203, 108, 230, 0.10);
	background: linear-gradient(135deg, #14121f 0%, #1d1a2e 100%);
}
.ced-cms__cat[data-slug="general"] {
	--cat-accent: var(--wp--preset--color--sky);
	--cat-tint:   rgba(203, 108, 230, 0.10);
	background: linear-gradient(135deg, #2a1f15 0%, #1a1410 100%);
}
.ced-cms__cat[data-slug="commerce"] {
	--cat-accent: var(--wp--preset--color--coral);
	--cat-tint:   rgba(203, 108, 230, 0.10);
	background: linear-gradient(135deg, #14121f 0%, #1d1a2e 100%);
}
.ced-cms__cat[data-slug="headless"] {
	--cat-accent: var(--wp--preset--color--lavender);
	--cat-tint:   rgba(203, 108, 230, 0.10);
	background: linear-gradient(135deg, #14121f 0%, #1d1a2e 100%);
}

/* Glow that hovers on category color */
.ced-cms__cat::after {
	content: "";
	position: absolute;
	inset: -1px;
	background: var(--cat-tint);
	opacity: 0;
	transition: opacity 520ms var(--ease-emph);
	pointer-events: none;
}
.ced-cms__cat:hover::after { opacity: 1; }

.ced-cms__cat-head {
	display: flex; align-items: baseline; gap: 1rem;
	border-bottom: var(--wp--custom--grid--hairline);
	padding-bottom: 1rem;
}
.ced-cms__cat-num {
	font-family: var(--wp--preset--font-family--mono);
	color: var(--cat-accent);
	font-size: var(--wp--preset--font-size--sm);
	letter-spacing: 0.08em;
}
.ced-cms__cat-name {
	font-size: clamp(1.4rem, 2.4vw, 2.1rem);
	font-weight: 500;
	letter-spacing: -0.025em;
	margin: 0;
	color: var(--wp--preset--color--paper);
}
.ced-cms__cat-desc {
	color: var(--wp--preset--color--mist);
	font-size: var(--wp--preset--font-size--sm);
	margin: 0;
	max-width: 50ch;
	line-height: 1.55;
}

/* --- Platform cards ------------------------------------------------ */
.ced-cms__cards {
	list-style: none;
	margin: auto 0 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.5rem;
}
@media (min-width: 540px)  { .ced-cms__cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .ced-cms__cards { grid-template-columns: repeat(3, 1fr); } }

.ced-cms-card {
	position: relative;
	border-radius: var(--wp--custom--radius--md);
	background: var(--ced-veil-40);
	border: 1px solid var(--ced-line-08);
	cursor: default;
	overflow: hidden;
	transition: border-color var(--wp--custom--transition--smooth), background var(--wp--custom--transition--smooth), transform var(--wp--custom--transition--smooth);
	/* Face + back share a single grid cell so the card sizes to the
	   taller of the two (the back, with up to 3 lines of detail).
	   Previously `min-height: 110px` + absolutely-positioned back
	   meant longer notes got clipped on hover. */
	display: grid;
	grid-template-areas: "stack";
}
.ced-cms-card:hover,
.ced-cms-card:focus-visible {
	border-color: var(--cat-accent);
	background: var(--wp--preset--color--ink);
	transform: translateY(-2px);
	box-shadow: 0 12px 32px -8px color-mix(in oklab, var(--cat-accent) 30%, transparent);
}

.ced-cms-card__face {
	grid-area: stack;
	z-index: 2;             /* sits over the back when both are visible */
	display: flex; align-items: center; justify-content: space-between;
	gap: 0.5rem;
	padding: 1rem 1.1rem;
	transition: opacity 320ms var(--ease-smooth), transform 320ms var(--ease-smooth);
}
.ced-cms-card:hover .ced-cms-card__face,
.ced-cms-card:focus-visible .ced-cms-card__face {
	opacity: 0;
	transform: translateY(-6px);
	pointer-events: none;   /* let underlying back receive clicks/focus */
}
.ced-cms-card__name {
	font-size: var(--wp--preset--font-size--base);
	font-weight: 500;
	letter-spacing: -0.01em;
	color: var(--wp--preset--color--paper);
}
.ced-cms-card__hint {
	color: var(--cat-accent);
	display: inline-flex;
}

.ced-cms-card__back {
	grid-area: stack;
	z-index: 1;
	padding: 0.85rem 1.1rem;
	display: flex; flex-direction: column;
	justify-content: center;  /* keep content centered while face overlays */
	gap: 0.4rem;
	opacity: 0;
	transform: translateY(6px);
	transition: opacity 320ms var(--ease-smooth) 60ms, transform 320ms var(--ease-smooth) 60ms;
}
.ced-cms-card:hover .ced-cms-card__back,
.ced-cms-card:focus-visible .ced-cms-card__back {
	opacity: 1;
	transform: translateY(0);
}
.ced-cms-card__back dl {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.5rem;
	margin: 0;
}
.ced-cms-card__back dt {
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--micro);
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--wp--preset--color--fog);
	margin: 0;
}
.ced-cms-card__back dd {
	font-size: var(--wp--preset--font-size--lg);
	font-weight: 500;
	color: var(--cat-accent);
	margin: 0;
	letter-spacing: -0.02em;
}
.ced-cms-card__back p {
	font-size: 0.78rem;
	color: var(--wp--preset--color--mist);
	margin: 0;
	line-height: 1.4;
}

/* --- Footer row ---------------------------------------------------- */
.ced-cms__foot {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	padding-top: var(--wp--preset--spacing--md);
}
.ced-cms__foot p {
	color: var(--wp--preset--color--mist);
	font-size: var(--wp--preset--font-size--lg);
	margin: 0;
	max-width: 40ch;
}

@media (max-width: 1024px) {
	.ced-cms__title { font-size: clamp(2rem, 5vw, 3.5rem); }
	.ced-cms__lede  { font-size: var(--wp--preset--font-size--base); }
	.ced-cms__cat   { padding: 1.75rem; min-height: 360px; }
}
@media (max-width: 640px) {
	.ced-cms__title { font-size: clamp(1.75rem, 8vw, 2.5rem); max-width: 100%; }
	.ced-cms__lede  { font-size: 0.95rem; }
	.ced-cms__head  { margin-bottom: 2rem; }
	.ced-cms__bento { border-radius: var(--wp--custom--radius--md); }
	.ced-cms__cat {
		padding: 1.5rem 0;
		min-height: auto;
		gap: 1.25rem;
	}
	.ced-cms__cat-head { padding-inline: 1.25rem; }
	.ced-cms__cat-desc { padding-inline: 1.25rem; }
	.ced-cms__cat-name { font-size: clamp(1.25rem, 6vw, 1.75rem); }
	.ced-cms__cat-desc { font-size: 0.85rem; }

	/* Platform cards become a swipe-snap row — all 3 visible by swipe,
	   no 3 stacked rows of vertical space on phones. */
	.ced-cms__cards {
		display: flex;
		flex-wrap: nowrap;
		gap: 0.65rem;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		scroll-padding-inline-start: 1.25rem;
		padding-inline: 1.25rem;
		padding-bottom: 0.5rem;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		grid-template-columns: none;
		/* Fade matches the per-category background tint */
		--ced-swipe-fade: rgba(15, 15, 18, 1);
		position: relative;
	}
	.ced-cms__cards::-webkit-scrollbar { display: none; }
	.ced-cms-card {
		flex: 0 0 auto;
		width: min(72vw, 280px);
		min-height: 130px;
		scroll-snap-align: start;
		scroll-snap-stop: always;
		/* On mobile we want face above back in natural flow, not
		   overlapping. Reset the desktop single-cell grid stack. */
		display: flex;
		flex-direction: column;
		grid-template-areas: none;
	}

	/* On mobile, show stats permanently (no flip), face above back. */
	.ced-cms-card__face {
		grid-area: auto;
		padding: 0.85rem 1rem 0.5rem;
		opacity: 1 !important;
		transform: none !important;
		pointer-events: auto !important;
	}
	.ced-cms-card__back {
		grid-area: auto;
		padding: 0 1rem 1rem;
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
		justify-content: flex-start;
	}
	.ced-cms-card__back dl { gap: 0.4rem; }
	.ced-cms-card__back dd { font-size: 0.95rem; }
	.ced-cms-card__back p  { font-size: 0.7rem; }
	.ced-cms-card:hover { transform: none !important; }

	.ced-cms__foot { flex-direction: column; align-items: flex-start; padding-inline: 1.25rem; }
	.ced-cms__foot p { font-size: 0.95rem; }
}
