/* comparison-table.css — depends on: el-tokens, el-base */

.comparison-table-wrap {
	container-name: comparison-table;
	container-type: inline-size;
}

.comparison-table-wrap .comparison-eyebrow {
	font-family: var(--el-font-display);
	font-size: var(--el-text-xs);
	font-weight: var(--el-weight-semibold);
	letter-spacing: var(--el-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--el-color-text-soft);
	margin: 0 0 var(--el-space-2);
}

.comparison-table-wrap .comparison-header {
	font-family: var(--el-font-display);
	font-size: var(--el-text-xl);
	font-weight: var(--el-weight-bold);
	margin: 0 0 var(--el-space-3);
}

.comparison-table-wrap .comparison-text {
	font-family: var(--el-font-body);
	font-size: var(--el-text-base);
	color: var(--el-color-text-soft);
	margin: 0 0 var(--el-space-5);
}

.comparison-table-wrap .closing-text {
	font-family: var(--el-font-serif);
	font-style: italic;
	font-size: var(--el-text-sm);
	color: var(--el-color-text-muted);
	margin: var(--el-space-3) 0 0;
}

.comparison-table-wrap .table-data {
	display: flex;
	flex-direction: column;
	gap: var(--el-space-2);
}

/* row-label only exists for mobile's shared criterion column — invisible on desktop */
.comparison-table-wrap .row-label {
	display: none;
}

.comparison-table-wrap .row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--el-space-2);
}

.comparison-table-wrap .table-header.row {
	position: relative;
	margin-bottom: var(--el-space-2);
}

.comparison-table-wrap .table-header.cell {
	padding: var(--el-space-5) var(--el-space-6);
	border-radius: var(--el-radius);
	text-align: center;
}

.comparison-table-wrap .table-header.cell h3 {
	font-family: var(--el-font-display);
	font-weight: var(--el-weight-bold);
	text-transform: uppercase;
	font-size: var(--el-text-2xl);
	color: var(--el-white);
	line-height: var(--el-leading-tight);
	margin: 0 0 4px;
}

.comparison-table-wrap .table-header.cell p {
	font-family: var(--el-font-body);
	font-size: var(--el-text-xs);
	font-weight: var(--el-weight-semibold);
	letter-spacing: 0.02em;
	color: rgba(255, 255, 255, 0.7);
	margin: 0;
}

.comparison-table-wrap .table-header.cell.us {
	background: var(--el-color-action);
}

.comparison-table-wrap .table-header.cell.them {
	background: var(--el-black);
}

.comparison-table-wrap .vs-badge {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 48px;
	height: 48px;
	border-radius: var(--el-radius-pill);
	background: var(--el-cream);
	border: 2px solid var(--el-color-action);
	color: var(--el-color-action);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--el-font-display);
	font-size: var(--el-text-xs);
	font-weight: var(--el-weight-bold);
	box-shadow: var(--el-shadow-sm);
}

.comparison-table-wrap .table-row.cell {
	display: flex;
	align-items: center;
	gap: var(--el-space-3);
	border-radius: var(--el-radius-sm);
	padding: var(--el-space-3) var(--el-space-4);
	border: 1px solid transparent;
	transition: background-color var(--el-duration) var(--el-ease), border-color var(--el-duration) var(--el-ease), box-shadow var(--el-duration) var(--el-ease);
}

.comparison-table-wrap .table-row.cell.us {
	background: var(--el-pine-tint);
	border-color: var(--el-color-border-offset);
}

.comparison-table-wrap .table-row.cell.them {
	background: var(--el-color-surface-warm);
	border-color: var(--el-color-border);
}

.comparison-table-wrap .table-row.cell.us.row-hover {
	border-color: var(--el-color-action);
	box-shadow: var(--el-shadow-sm);
}

.comparison-table-wrap .table-row.cell.them.row-hover {
	border-color: var(--el-sage-soft);
	box-shadow: var(--el-shadow-sm);
}

.comparison-table-wrap .cell-text h3 {
	font-family: var(--el-font-display);
	font-weight: var(--el-weight-bold);
	text-transform: uppercase;
	font-size: var(--el-text-lg);
	color: var(--el-color-text);
	line-height: var(--el-leading-tight);
	margin: 0 0 2px;
}

.comparison-table-wrap .table-row.cell.them .cell-text h3 {
	color: var(--el-color-text-soft);
}

.comparison-table-wrap .cell-text p {
	font-family: var(--el-font-body);
	font-size: var(--el-text-base);
	color: var(--el-color-text);
	line-height: var(--el-leading-snug);
	margin: 0;
}

.comparison-table-wrap .ic {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	flex-shrink: 0;
	border-radius: var(--el-radius-pill);
}

.comparison-table-wrap .ic.check {
	background: var(--el-pine-tint);
	color: var(--el-color-action);
}

.comparison-table-wrap .ic.cross {
	background: var(--el-color-surface-warm);
	color: var(--el-color-text-muted);
}

/* ── narrow: reflow to label + icon-only columns ─────────────────────── */
@container comparison-table (max-width: 540px) {
	.comparison-table-wrap .row-label {
		display: flex;
		align-items: center;
		font-family: var(--el-font-display);
		font-weight: var(--el-weight-bold);
		text-transform: uppercase;
		font-size: var(--el-text-xs);
		letter-spacing: 0.02em;
		color: var(--el-color-text);
	}

	.comparison-table-wrap .row {
		grid-template-columns: 1fr auto auto;
		align-items: center;
		gap: var(--el-space-1);
	}

	.comparison-table-wrap .table-header.cell h3 {
		font-size: var(--el-text-sm);
		letter-spacing: 0.02em;
	}

	.comparison-table-wrap .table-header.cell p {
		display: none;
	}

	.comparison-table-wrap .table-header.cell {
		padding: var(--el-space-3) var(--el-space-2);
		border-radius: var(--el-radius-sm);
	}

	.comparison-table-wrap .vs-badge {
		width: 36px;
		height: 36px;
		font-size: 0.6rem;
	}

	.comparison-table-wrap .table-row.cell {
		justify-content: center;
		padding: var(--el-space-2);
	}

	.comparison-table-wrap .cell-text {
		display: none;
	}

	/* icon-only on narrow screens */

	.comparison-table-wrap .table-data .row:nth-child(even) {
		background: var(--el-color-surface-warm);
		border-radius: var(--el-radius-sm);
	}
}