/* Module card — composes the card primitive.
   The card owns the surface (padding, border, radius, hover lift); this file
   styles only the content inside: icon tile · body · CTA. */

.dt-module-card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
	height: 100%;
}

/* ---------- Badge chip (pro / new / popular) ---------- */

.dt-module-card__badge {
	position: absolute;
	top: var(--space-4);
	right: var(--space-4);
	display: inline-flex;
	align-items: center;
	padding: 1px var(--space-2);
	font-size: var(--fs-xs);
	font-weight: var(--fw-bold);
	letter-spacing: var(--ls-eyebrow);
	text-transform: uppercase;
	border-radius: var(--radius-pill);
	line-height: 1.4;
	z-index: 1;
}

.dt-module-card__badge--pro {
	color: var(--dt-on-primary);
	background: var(--dt-primary);
}

.dt-module-card__badge--new {
	color: var(--dt-success);
	background: color-mix(in srgb, var(--dt-success) 14%, transparent);
}

.dt-module-card__badge--popular {
	color: var(--dt-ink-soft);
	background: var(--dt-bg-alt);
	border: 1px solid var(--dt-border);
}

/* ---------- Icon tile (tinted, prominent) ---------- */

.dt-module-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-md);
	background: var(--dt-primary-soft);
	color: var(--dt-primary);
	flex-shrink: 0;
	transition: background var(--duration-2) var(--ease-out),
	            transform var(--duration-2) var(--ease-out);
}

.dt-card--interactive:hover .dt-module-card__icon {
	background: color-mix(in srgb, var(--dt-primary) 18%, var(--dt-primary-soft));
	transform: scale(1.05);
}

/* ---------- Body ---------- */

.dt-module-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	flex: 1;
}

.dt-module-card__name {
	margin: 0;
	font-size: var(--fs-md);
	font-weight: var(--fw-semibold);
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-snug);
	color: var(--dt-ink);
}

.dt-module-card__tagline {
	margin: 0;
	font-size: var(--fs-sm);
	line-height: var(--lh-normal);
	color: var(--dt-ink-soft);
}

/* ---------- Hover CTA — appears at the bottom on hover ---------- */

.dt-module-card__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	margin-top: auto;
	font-size: var(--fs-xs);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-eyebrow);
	text-transform: uppercase;
	color: var(--dt-primary);
	opacity: 0;
	transform: translateY(4px);
	transition: opacity var(--duration-2) var(--ease-out),
	            transform var(--duration-2) var(--ease-out),
	            gap var(--duration-2) var(--ease-out);
}

.dt-card--interactive:hover .dt-module-card__cta {
	opacity: 1;
	transform: translateY(0);
	gap: var(--space-3);
}

.dt-module-card__cta-label { line-height: 1; }

/* ---------- "... and that's not all" + See all features button ---------- */

.dt-features-more {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-3);
	margin-inline: auto;
}

.dt-features-more__hint {
	margin: 0;
	font-size: var(--fs-md);
	color: var(--dt-ink-soft);
	font-style: italic;
}

/* ---------- Compact variant — clean square cells for the "all modules" grid.
   Icon centered top, name centered below, no tinted icon disc, no shadow.
   Reads as a light index of names rather than a row of heavy cards. */

.dt-module-card--compact {
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: var(--space-3);
	aspect-ratio: 1 / 1;
}

.dt-module-card--compact .dt-module-card__icon {
	width: auto;
	height: auto;
	background: transparent;
	color: var(--dt-ink);
	transition: transform var(--duration-2) var(--ease-out),
	            color var(--duration-1) var(--ease-out);
}

/* Hover only — bring the brand accent in then. */
.dt-card--interactive.dt-module-card--compact:hover .dt-module-card__icon {
	color: var(--dt-primary);
}

/* Lighter hover for the compact cell — no lift, no shadow, just bg + icon scale.
   The card primitive normally adds a shadow + translateY on hover; we override
   so the grid of 16 cells feels like a calm index rather than a heavy hover-set. */
.dt-card--interactive.dt-module-card--compact {
	box-shadow: none;
}

.dt-card--interactive.dt-module-card--compact:hover {
	box-shadow: none;
	transform: none;
	background: var(--dt-bg-alt);
	border-color: var(--dt-border);
}

.dt-card--interactive.dt-module-card--compact:hover .dt-module-card__icon {
	background: transparent;
	transform: scale(1.08);
}

.dt-module-card--compact .dt-module-card__body {
	gap: 0;
	flex: 0;
	min-width: 0;
	align-items: center;
}

.dt-module-card--compact .dt-module-card__name {
	font-size: var(--fs-sm);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-snug);
	line-height: var(--lh-snug);
	color: var(--dt-ink);
}

/* ---------- Touch / narrow screens: always show CTA ---------- */

@media (max-width: 600px) {
	.dt-module-card__icon {
		width: 40px;
		height: 40px;
	}

	.dt-module-card__cta {
		opacity: 1;
		transform: translateY(0);
	}

	.dt-module-card--compact .dt-module-card__icon {
		width: 28px;
		height: 28px;
	}
}
