/* NE Design System — modules/mod-specs.css (#367, #368, #405) */
/* Technical specs grid for car pages and feature flags for track pages. */

/* === Specs Grid Layout === */
.ne-specs-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--ne-space-3);
}

@media (max-width: 1024px) {
	.ne-specs-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.ne-specs-grid {
		grid-template-columns: 1fr;
	}
}

/* === Spec Card === */
.ne-spec-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ne-space-1);
	padding: var(--ne-space-3);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
	text-align: center;
	transition: border-color 0.2s ease;
}

.ne-spec-card--yes {
	border-color: var(--ne-green);
}

.ne-spec-card--no {
	opacity: 0.45;
}

/* === Spec Icon === */
.ne-spec-icon {
	font-size: 1.25rem;
	line-height: 1;
	width: 2rem;
	height: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--ne-radius-sm);
	background: var(--ne-elevated, rgba(255, 255, 255, 0.05));
	color: var(--ne-text-muted);
}

.ne-spec-card--yes .ne-spec-icon {
	color: var(--ne-green);
	background: rgba(61, 214, 140, 0.1);
}

.ne-spec-card--no .ne-spec-icon {
	color: var(--ne-text-muted);
}

/* === Spec Label === */
.ne-spec-label {
	font-size: var(--ne-text-xs, 0.75rem);
	color: var(--ne-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	line-height: 1.3;
}

/* === Spec Value === */
.ne-spec-value {
	font-size: var(--ne-text-sm, 0.875rem);
	font-weight: 600;
	color: var(--ne-text);
	line-height: 1.3;
}

.ne-spec-card--no .ne-spec-value {
	color: var(--ne-text-muted);
}

/* === Power Curve Chart Container === */
.ne-power-curve {
	margin-top: var(--ne-space-4);
}

.ne-power-curve__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--ne-space-3);
	flex-wrap: wrap;
	gap: var(--ne-space-2);
}

.ne-power-curve__peaks {
	display: flex;
	gap: var(--ne-space-4);
	font-size: var(--ne-text-sm, 0.875rem);
}

.ne-power-curve__peak {
	display: flex;
	align-items: center;
	gap: var(--ne-space-1);
}

.ne-power-curve__peak-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	display: inline-block;
}

.ne-power-curve__peak-dot--torque {
	background: #3b82f6;
}

.ne-power-curve__peak-dot--power {
	background: #ef4444;
}

.ne-power-curve__peak-value {
	font-weight: 600;
	color: var(--ne-text);
}

.ne-power-curve__peak-unit {
	color: var(--ne-text-muted);
}

.ne-power-curve canvas {
	border-radius: var(--ne-radius-md);
	background: var(--ne-surface);
}

/* === Feature Grid (tracks) === */
.ne-features-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--ne-space-3);
}

@media (max-width: 1024px) {
	.ne-features-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 480px) {
	.ne-features-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.ne-feature-card {
	display: flex;
	align-items: center;
	gap: var(--ne-space-2);
	padding: var(--ne-space-2) var(--ne-space-3);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
	transition: border-color 0.2s ease;
}

.ne-feature-card--yes {
	border-color: var(--ne-green);
}

.ne-feature-card--no {
	opacity: 0.4;
}

.ne-feature-icon {
	font-size: 1rem;
	width: 1.5rem;
	flex-shrink: 0;
	text-align: center;
}

.ne-feature-card--yes .ne-feature-icon {
	color: var(--ne-green);
}

.ne-feature-card--no .ne-feature-icon {
	color: var(--ne-text-muted);
}

.ne-feature-label {
	font-size: var(--ne-text-sm, 0.875rem);
	color: var(--ne-text);
}

.ne-feature-card--no .ne-feature-label {
	color: var(--ne-text-muted);
}
