/**
 * Viaturas — Estilos públicos (M7).
 *
 * Componentes:
 *  - Container + breadcrumbs
 *  - Hero: galeria + info side-by-side
 *  - Galeria: main + thumbs + placeholder
 *  - Estado pill (com cor dinâmica via CSS var)
 *  - Preço block + IVA flags + etiquetas
 *  - CTAs (vermelho Moticristo #E52528 + outline)
 *  - Specs grid (3-4 colunas em desktop)
 *  - Equipment 3 colunas
 *  - Condições card grid (garantia + crédito)
 *  - Related cards
 *  - Lightbox overlay
 *
 * @package moticristo-child
 */

:root {
	--mc-viatura-primary: #E52528;
	--mc-viatura-primary-dark: #c01e21;
	--mc-viatura-text: #1a1a1a;
	--mc-viatura-text-muted: #595959;
	--mc-viatura-text-light: #8a8a8a;
	--mc-viatura-border: #e5e7eb;
	--mc-viatura-border-light: #f0f1f3;
	--mc-viatura-bg: #ffffff;
	--mc-viatura-bg-soft: #f8f9fa;
	--mc-viatura-radius: 8px;
	--mc-viatura-radius-sm: 6px;
	--mc-viatura-shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
	--mc-viatura-shadow: 0 4px 16px rgba(0,0,0,0.08);
}

/* ============================================================================
 * Container + breadcrumbs
 * ============================================================================ */

.mc-viatura-single {
	font-family: Montserrat, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	color: var(--mc-viatura-text);
	background: var(--mc-viatura-bg);
	padding: 32px 0 64px;
}

.mc-viatura-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

.mc-viatura-breadcrumbs {
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
	margin-bottom: 24px;
}

.mc-viatura-breadcrumbs a {
	color: var(--mc-viatura-text-muted);
	text-decoration: none;
}

.mc-viatura-breadcrumbs a:hover {
	color: var(--mc-viatura-primary);
}

.mc-viatura-breadcrumbs .sep {
	margin: 0 6px;
	color: var(--mc-viatura-text-light);
}

.mc-viatura-breadcrumbs .current {
	color: var(--mc-viatura-text);
	font-weight: 500;
}

/* ============================================================================
 * Hero — Galeria + Info
 * ============================================================================ */

.mc-viatura-hero {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 380px);
	gap: 32px;
	margin-bottom: 48px;
}

@media (max-width: 900px) {
	.mc-viatura-hero {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

/* ============================================================================
 * Galeria
 * ============================================================================ */

.mc-viatura-gallery {
	min-width: 0;
}

.mc-viatura-gallery-main {
	background: #0F1216;
	border-radius: var(--mc-viatura-radius);
	overflow: hidden;
	margin-bottom: 12px;
	position: relative;
}

.mc-viatura-gallery-main-btn {
	display: block;
	width: 100%;
	border: none;
	padding: 0;
	background: none;
	cursor: zoom-in;
	position: relative;
	margin: 0;
}

.mc-viatura-gallery-main-img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

.mc-viatura-gallery-zoom-icon {
	position: absolute;
	top: 16px;
	right: 16px;
	background: rgba(0,0,0,0.55);
	color: #fff;
	padding: 6px 10px;
	border-radius: 4px;
	font-size: 18px;
	line-height: 1;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.mc-viatura-gallery-main-btn:hover .mc-viatura-gallery-zoom-icon,
.mc-viatura-gallery-main-btn:focus .mc-viatura-gallery-zoom-icon {
	opacity: 1;
}

.mc-viatura-gallery-counter {
	position: absolute;
	bottom: 16px;
	right: 16px;
	background: rgba(0,0,0,0.6);
	color: #fff;
	padding: 7px 12px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 500;
	pointer-events: none;
}

.mc-viatura-gallery-thumbs {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
	gap: 8px;
}

.mc-viatura-gallery-thumb {
	border: 2px solid transparent;
	background: var(--mc-viatura-bg-soft);
	border-radius: var(--mc-viatura-radius-sm);
	overflow: hidden;
	padding: 0;
	cursor: pointer;
	transition: border-color 0.15s, transform 0.15s;
	aspect-ratio: 4 / 3;
}

.mc-viatura-gallery-thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mc-viatura-gallery-thumb:hover {
	border-color: var(--mc-viatura-border);
}

.mc-viatura-gallery-thumb.is-active {
	border-color: var(--mc-viatura-primary);
}

.mc-viatura-gallery-thumb:focus-visible {
	outline: 2px solid var(--mc-viatura-primary);
	outline-offset: 2px;
}

.mc-viatura-gallery-placeholder {
	background: var(--mc-viatura-bg-soft);
	border-radius: var(--mc-viatura-radius);
	aspect-ratio: 4 / 3;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
	color: var(--mc-viatura-text-light);
}

.mc-viatura-gallery-placeholder span {
	font-size: 64px;
	opacity: 0.5;
}

/* ============================================================================
 * Info column
 * ============================================================================ */

.mc-viatura-info {
	display: flex;
	flex-direction: column;
	gap: 18px;
}

.mc-viatura-info-header {
	border-bottom: 1px solid var(--mc-viatura-border-light);
	padding-bottom: 18px;
}

.mc-viatura-marca {
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--mc-viatura-text-muted);
	margin: 0 0 4px;
}

.mc-viatura-titulo {
	font-size: 28px;
	font-weight: 700;
	line-height: 1.15;
	margin: 0 0 8px;
	color: var(--mc-viatura-text);
}

.mc-viatura-titulo .mc-viatura-ano {
	color: var(--mc-viatura-text-muted);
	font-weight: 500;
	margin-left: 6px;
}

.mc-viatura-info-meta {
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
	margin: 0;
}

.mc-viatura-matricula {
	background: var(--mc-viatura-bg-soft);
	padding: 2px 8px;
	border-radius: 4px;
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--mc-viatura-text);
}

.mc-viatura-info-meta .sep {
	margin: 0 8px;
	color: var(--mc-viatura-text-light);
}

/* Estado pill */
.mc-viatura-estado-pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 14px;
	border-radius: 100px;
	background: color-mix(in srgb, var(--estado-color, #787c82) 12%, white);
	color: var(--estado-color, #787c82);
	font-size: 13px;
	font-weight: 600;
	width: fit-content;
}

.mc-viatura-estado-pill .dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--estado-color, currentColor);
}

/* Fallback para browsers sem color-mix */
@supports not (background: color-mix(in srgb, red, white)) {
	.mc-viatura-estado-pill {
		background: var(--mc-viatura-bg-soft);
	}
}

/* Preço block */
.mc-viatura-preco-block {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.mc-viatura-preco {
	font-size: 32px;
	font-weight: 700;
	color: var(--mc-viatura-text);
	line-height: 1;
}

.mc-viatura-iva-flags {
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
}

/* Etiquetas */
.mc-viatura-etiquetas {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.mc-viatura-etiqueta {
	background: var(--mc-viatura-primary);
	color: #fff;
	padding: 3px 10px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

/* CTAs */
.mc-viatura-ctas {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 6px;
}

.mc-viatura-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 20px;
	border-radius: var(--mc-viatura-radius-sm);
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.15s;
	border: 2px solid transparent;
	cursor: pointer;
	text-align: center;
}

.mc-viatura-btn--primary {
	background: var(--mc-viatura-primary);
	color: #fff;
	border-color: var(--mc-viatura-primary);
}

.mc-viatura-btn--primary:hover,
.mc-viatura-btn--primary:focus {
	background: var(--mc-viatura-primary-dark);
	border-color: var(--mc-viatura-primary-dark);
	color: #fff;
	transform: translateY(-1px);
}

.mc-viatura-btn--outline {
	background: transparent;
	color: var(--mc-viatura-primary);
	border-color: var(--mc-viatura-primary);
}

.mc-viatura-btn--outline:hover,
.mc-viatura-btn--outline:focus {
	background: var(--mc-viatura-primary);
	color: #fff;
}

.mc-viatura-trust {
	font-size: 12px;
	color: var(--mc-viatura-text-light);
	text-align: center;
	margin: 4px 0 0;
}

/* ============================================================================
 * Sections genéricas
 * ============================================================================ */

.mc-viatura-section {
	margin-bottom: 48px;
}

.mc-viatura-section-title {
	font-size: 22px;
	font-weight: 700;
	margin: 0 0 20px;
	color: var(--mc-viatura-text);
	padding-bottom: 12px;
	border-bottom: 2px solid var(--mc-viatura-primary);
	display: inline-block;
}

/* ============================================================================
 * Specs grid
 * ============================================================================ */

.mc-viatura-specs-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1px;
	background: var(--mc-viatura-border-light);
	border: 1px solid var(--mc-viatura-border-light);
	border-radius: var(--mc-viatura-radius);
	overflow: hidden;
	margin: 0;
}

.mc-viatura-spec {
	background: #fff;
	padding: 16px 18px;
	margin: 0;
}

.mc-viatura-spec-label {
	display: block;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--mc-viatura-text-muted);
	margin-bottom: 4px;
}

.mc-viatura-spec-value {
	display: block;
	font-size: 16px;
	font-weight: 600;
	color: var(--mc-viatura-text);
	margin: 0;
}

/* ============================================================================
 * Equipment
 * ============================================================================ */

.mc-viatura-equipment-cols {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
}

.mc-viatura-equipment-col {
	background: var(--mc-viatura-bg-soft);
	padding: 20px;
	border-radius: var(--mc-viatura-radius);
}

.mc-viatura-equipment-col-title {
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--mc-viatura-text);
	margin: 0 0 12px;
}

.mc-viatura-equipment-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.mc-viatura-equipment-list li {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	padding: 6px 0;
	font-size: 14px;
	color: var(--mc-viatura-text);
}

.mc-viatura-equipment-list .check {
	color: var(--mc-viatura-primary);
	font-weight: 700;
	flex-shrink: 0;
	width: 18px;
}

/* ============================================================================
 * Condições (garantia + crédito)
 * ============================================================================ */

.mc-viatura-conditions-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
}

.mc-viatura-condition-card {
	background: var(--mc-viatura-bg-soft);
	padding: 24px;
	border-radius: var(--mc-viatura-radius);
	border-left: 4px solid var(--mc-viatura-primary);
}

.mc-viatura-condition-card h3 {
	font-size: 16px;
	font-weight: 700;
	margin: 0 0 12px;
	color: var(--mc-viatura-text);
}

.mc-viatura-condition-body {
	font-size: 14px;
	line-height: 1.6;
	color: var(--mc-viatura-text);
}

.mc-viatura-condition-body p {
	margin: 0 0 8px;
}

.mc-viatura-condition-body p:last-child {
	margin-bottom: 0;
}

.mc-viatura-condition-link {
	display: inline-block;
	margin-top: 14px;
	color: var(--mc-viatura-primary);
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
}

.mc-viatura-condition-link:hover {
	color: var(--mc-viatura-primary-dark);
	text-decoration: underline;
}

/* ============================================================================
 * Cards (related + archive em M7b)
 * ============================================================================ */

.mc-viatura-related-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 20px;
}

.mc-viatura-card {
	background: #fff;
	border-radius: var(--mc-viatura-radius);
	overflow: hidden;
	box-shadow: var(--mc-viatura-shadow-sm);
	transition: transform 0.2s, box-shadow 0.2s;
}

.mc-viatura-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--mc-viatura-shadow);
}

.mc-viatura-card-link {
	display: block;
	color: inherit;
	text-decoration: none;
}

.mc-viatura-card-capa {
	position: relative;
	background: var(--mc-viatura-bg-soft);
	aspect-ratio: 4 / 3;
	overflow: hidden;
}

.mc-viatura-card-capa img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mc-viatura-card-capa-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 48px;
	opacity: 0.4;
}

.mc-viatura-card-estado {
	position: absolute;
	top: 10px;
	left: 10px;
	background: color-mix(in srgb, var(--estado-color, #787c82) 12%, white);
	color: var(--estado-color, #787c82);
	font-size: 11px;
	font-weight: 600;
	padding: 3px 8px;
	border-radius: 4px;
}

@supports not (background: color-mix(in srgb, red, white)) {
	.mc-viatura-card-estado {
		background: rgba(255,255,255,0.95);
	}
}

.mc-viatura-card-body {
	padding: 14px 16px 16px;
}

.mc-viatura-card-titulo {
	font-size: 16px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--mc-viatura-text);
	line-height: 1.2;
}

.mc-viatura-card-titulo .ano {
	color: var(--mc-viatura-text-muted);
	font-weight: 500;
	font-size: 14px;
}

.mc-viatura-card-specs {
	font-size: 12px;
	color: var(--mc-viatura-text-muted);
	margin: 0 0 10px;
}

.mc-viatura-card-preco {
	font-size: 18px;
	font-weight: 700;
	color: var(--mc-viatura-primary);
	margin: 0;
}

.mc-viatura-card-preco .iva {
	font-size: 11px;
	font-weight: 500;
	color: var(--mc-viatura-text-muted);
	margin-left: 4px;
}

/* ============================================================================
 * Lightbox
 * ============================================================================ */

.mc-viatura-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.92);
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mc-viatura-lightbox[hidden] {
	display: none;
}

.mc-viatura-lightbox-content {
	max-width: 90vw;
	max-height: 85vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mc-viatura-lightbox-img {
	max-width: 100%;
	max-height: 85vh;
	display: block;
	border-radius: 4px;
	box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}

.mc-viatura-lightbox-close,
.mc-viatura-lightbox-prev,
.mc-viatura-lightbox-next {
	position: absolute;
	background: rgba(255,255,255,0.1);
	color: #fff;
	border: none;
	cursor: pointer;
	font-family: inherit;
	transition: background 0.15s, transform 0.15s;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mc-viatura-lightbox-close {
	top: 20px;
	right: 20px;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	font-size: 28px;
	line-height: 1;
}

.mc-viatura-lightbox-prev,
.mc-viatura-lightbox-next {
	top: 50%;
	transform: translateY(-50%);
	width: 56px;
	height: 56px;
	border-radius: 50%;
	font-size: 36px;
	line-height: 1;
}

.mc-viatura-lightbox-prev {
	left: 20px;
}

.mc-viatura-lightbox-next {
	right: 20px;
}

.mc-viatura-lightbox-close:hover,
.mc-viatura-lightbox-prev:hover,
.mc-viatura-lightbox-next:hover {
	background: rgba(255,255,255,0.2);
}

.mc-viatura-lightbox-prev:hover,
.mc-viatura-lightbox-next:hover {
	transform: translateY(-50%) scale(1.05);
}

.mc-viatura-lightbox-counter {
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	background: rgba(255,255,255,0.1);
	color: #fff;
	padding: 8px 16px;
	border-radius: 100px;
	font-size: 13px;
	font-weight: 500;
}

/* Lock body scroll quando lightbox aberto */
body.mc-viatura-lightbox-open {
	overflow: hidden;
}

/* ============================================================================
 * Responsive
 * ============================================================================ */

@media (max-width: 720px) {
	.mc-viatura-titulo {
		font-size: 24px;
	}

	.mc-viatura-preco {
		font-size: 26px;
	}

	.mc-viatura-section-title {
		font-size: 18px;
	}

	.mc-viatura-gallery-thumbs {
		grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
		gap: 6px;
	}

	.mc-viatura-lightbox-prev,
	.mc-viatura-lightbox-next {
		width: 44px;
		height: 44px;
		font-size: 28px;
	}

	.mc-viatura-lightbox-prev {
		left: 8px;
	}

	.mc-viatura-lightbox-next {
		right: 8px;
	}
}

@media (max-width: 480px) {
	.mc-viatura-single {
		padding: 20px 0 48px;
	}

	.mc-viatura-container {
		padding: 0 14px;
	}
}

/* ============================================================================
 * M7a-patch2 — Overrides do reset.css do Hello Elementor
 *
 * O reset define cores magenta (#CC3366) que vazam para bg/border/outline
 * dos nossos buttons. Overrides scoped por componente, com especificidade
 * suficiente para vencer .mc-viatura-single button mas SEM matar os bg dos
 * botões primários.
 * ============================================================================ */

/* Anular focus outline default em imagens (não em buttons — só onde queremos) */
.mc-viatura-single img {
	outline: none;
}

/* --- Gallery thumbnails --- */
.mc-viatura-single .mc-viatura-gallery-thumb,
.mc-viatura-single .mc-viatura-gallery-thumb:hover,
.mc-viatura-single .mc-viatura-gallery-thumb:focus {
	color: inherit;
	outline: none;
	background-color: var(--mc-viatura-bg-soft);
	border-width: 2px;
	border-style: solid;
}

.mc-viatura-single .mc-viatura-gallery-thumb {
	border-color: transparent;
}

.mc-viatura-single .mc-viatura-gallery-thumb:hover {
	border-color: var(--mc-viatura-border);
}

.mc-viatura-single .mc-viatura-gallery-thumb.is-active {
	border-color: var(--mc-viatura-primary);
}

.mc-viatura-single .mc-viatura-gallery-thumb:focus-visible {
	outline: 2px solid var(--mc-viatura-primary);
	outline-offset: 2px;
}

/* --- Gallery main button (zoom para lightbox) --- */
.mc-viatura-single .mc-viatura-gallery-main-btn,
.mc-viatura-single .mc-viatura-gallery-main-btn:hover,
.mc-viatura-single .mc-viatura-gallery-main-btn:focus {
	background-color: transparent;
	border: none;
	outline: none;
	color: inherit;
	/* O reset.css aplica padding:.5rem 1rem a todos os <button>; aqui o botão
	   embrulha a imagem, por isso esse padding criava uma moldura desigual
	   (16px lados / 8px topo). Anula-se para a foto preencher de bordo a bordo. */
	padding: 0 !important;
	display: block !important;
	line-height: 0 !important;
}

/* --- Modal contact close button --- */
.mc-viatura-single .mc-viatura-contact-close {
	background-color: transparent;
	border: none;
	outline: none;
	color: var(--mc-viatura-text-light);
}

.mc-viatura-single .mc-viatura-contact-close:hover,
.mc-viatura-single .mc-viatura-contact-close:focus {
	background-color: var(--mc-viatura-bg-soft);
	color: var(--mc-viatura-text);
	border: none;
	outline: none;
}

/* --- Lightbox close/prev/next buttons --- */
.mc-viatura-single .mc-viatura-lightbox-close,
.mc-viatura-single .mc-viatura-lightbox-prev,
.mc-viatura-single .mc-viatura-lightbox-next {
	background-color: rgba(255, 255, 255, 0.1);
	border: none;
	outline: none;
	color: #fff;
}

.mc-viatura-single .mc-viatura-lightbox-close:hover,
.mc-viatura-single .mc-viatura-lightbox-prev:hover,
.mc-viatura-single .mc-viatura-lightbox-next:hover,
.mc-viatura-single .mc-viatura-lightbox-close:focus,
.mc-viatura-single .mc-viatura-lightbox-prev:focus,
.mc-viatura-single .mc-viatura-lightbox-next:focus {
	background-color: rgba(255, 255, 255, 0.2);
	color: #fff;
}

/* --- CTAs principais: forçar bg + border + color com especificidade scoped --- */
/* (.mc-viatura-single + classe = 0,2,0 — vence .mc-viatura-btn--primary 0,1,0) */

.mc-viatura-single .mc-viatura-btn,
.mc-viatura-single .mc-viatura-btn:link,
.mc-viatura-single .mc-viatura-btn:visited {
	outline: none;
}

.mc-viatura-single .mc-viatura-btn--primary,
.mc-viatura-single .mc-viatura-btn--primary:link,
.mc-viatura-single .mc-viatura-btn--primary:visited {
	background-color: var(--mc-viatura-primary);
	border-color: var(--mc-viatura-primary);
	color: #fff;
}

.mc-viatura-single .mc-viatura-btn--primary:hover,
.mc-viatura-single .mc-viatura-btn--primary:focus,
.mc-viatura-single .mc-viatura-btn--primary:active {
	background-color: var(--mc-viatura-primary-dark);
	border-color: var(--mc-viatura-primary-dark);
	color: #fff;
	outline: none;
}

.mc-viatura-single .mc-viatura-btn--outline,
.mc-viatura-single .mc-viatura-btn--outline:link,
.mc-viatura-single .mc-viatura-btn--outline:visited {
	background-color: transparent;
	border-color: var(--mc-viatura-primary);
	color: var(--mc-viatura-primary);
}

.mc-viatura-single .mc-viatura-btn--outline:hover,
.mc-viatura-single .mc-viatura-btn--outline:focus,
.mc-viatura-single .mc-viatura-btn--outline:active {
	background-color: var(--mc-viatura-primary);
	border-color: var(--mc-viatura-primary);
	color: #fff;
	outline: none;
}

/* --- Submit button do modal (também é .mc-viatura-btn--primary mas dentro do modal) --- */
.mc-viatura-single .mc-viatura-contact-submit,
.mc-viatura-single .mc-viatura-contact-submit:hover,
.mc-viatura-single .mc-viatura-contact-submit:focus,
.mc-viatura-single .mc-viatura-contact-submit:active {
	border: 2px solid var(--mc-viatura-primary);
	outline: none;
}

.mc-viatura-single .mc-viatura-contact-submit {
	background-color: var(--mc-viatura-primary);
	color: #fff;
}

.mc-viatura-single .mc-viatura-contact-submit:hover,
.mc-viatura-single .mc-viatura-contact-submit:focus {
	background-color: var(--mc-viatura-primary-dark);
	border-color: var(--mc-viatura-primary-dark);
	color: #fff;
}

/* --- Inputs do form de contacto: anular outline default magenta --- */
.mc-viatura-single .mc-viatura-contact-field input,
.mc-viatura-single .mc-viatura-contact-field textarea {
	outline: none;
	box-shadow: none;
}

/* --- Lock down any anchor inside .mc-viatura-single that inherits magenta from reset --- */
.mc-viatura-single a {
	color: var(--mc-viatura-primary);
}

.mc-viatura-single a:hover {
	color: var(--mc-viatura-primary-dark);
}

/* Mas exceptuar links dentro de breadcrumbs (que já têm regra mais específica) */
.mc-viatura-single .mc-viatura-breadcrumbs a {
	color: var(--mc-viatura-text-muted);
}

.mc-viatura-single .mc-viatura-breadcrumbs a:hover {
	color: var(--mc-viatura-primary);
}

/* E o link dentro do card de viatura — herda inherit normalmente */
.mc-viatura-single .mc-viatura-card-link {
	color: inherit;
}

.mc-viatura-single .mc-viatura-card-link:hover {
	color: inherit;
}

/* ============================================================================
 * Specs grid — refactor para suportar ícone + texto
 * ============================================================================ */

.mc-viatura-spec {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 18px;
}

.mc-viatura-spec-icon {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	color: var(--mc-viatura-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.mc-viatura-spec-icon svg {
	width: 100%;
	height: 100%;
	display: block;
}

.mc-viatura-spec-text {
	flex: 1;
	min-width: 0;
}

/* Reset do display: block antigo nos labels/values, agora estão dentro de flex */
.mc-viatura-spec-label {
	margin-bottom: 2px;
}

/* ============================================================================
 * Modal de contacto
 * ============================================================================ */

.mc-viatura-contact {
	position: fixed;
	inset: 0;
	z-index: 999998;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
	font-family: Montserrat, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	animation: mc-viatura-contact-fadein 0.2s ease-out;
}

.mc-viatura-contact[hidden] {
	display: none;
}

@keyframes mc-viatura-contact-fadein {
	from { opacity: 0; }
	to { opacity: 1; }
}

.mc-viatura-contact-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.55);
	backdrop-filter: blur(2px);
	cursor: pointer;
}

.mc-viatura-contact-card {
	position: relative;
	background: #fff;
	border-radius: 12px;
	max-width: 480px;
	width: 100%;
	max-height: 90vh;
	overflow-y: auto;
	padding: 36px 32px 28px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	animation: mc-viatura-contact-slidein 0.25s ease-out;
}

@keyframes mc-viatura-contact-slidein {
	from { transform: translateY(20px); opacity: 0; }
	to { transform: translateY(0); opacity: 1; }
}

.mc-viatura-contact-close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 36px;
	height: 36px;
	border: none;
	background: transparent;
	color: var(--mc-viatura-text-light);
	cursor: pointer;
	font-size: 24px;
	line-height: 1;
	border-radius: 50%;
	transition: background 0.15s, color 0.15s;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mc-viatura-contact-close:hover,
.mc-viatura-contact-close:focus {
	background: var(--mc-viatura-bg-soft);
	color: var(--mc-viatura-text);
	outline: none;
}

.mc-viatura-contact-header {
	margin-bottom: 24px;
}

.mc-viatura-contact-header h2 {
	font-size: 26px;
	font-weight: 700;
	margin: 0 0 6px;
	color: var(--mc-viatura-text);
	line-height: 1.15;
}

.mc-viatura-contact-subtitle {
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
	margin: 0;
}

/* Vehicle "chip" */
.mc-viatura-contact-vehicle {
	background: var(--mc-viatura-bg-soft);
	border-left: 3px solid var(--mc-viatura-primary);
	padding: 12px 14px;
	border-radius: var(--mc-viatura-radius-sm);
	margin-bottom: 22px;
}

.mc-viatura-contact-vehicle .label {
	display: block;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--mc-viatura-text-muted);
	margin-bottom: 2px;
}

.mc-viatura-contact-vehicle .value {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: var(--mc-viatura-text);
}

/* Honey-pot — escondido visualmente mas acessível */
.mc-viatura-contact-hp {
	position: absolute;
	left: -9999px;
	top: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Form fields — estilo underline (inspirado no print do João) */
.mc-viatura-contact-field {
	margin-bottom: 18px;
	position: relative;
}

.mc-viatura-contact-field label {
	display: block;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--mc-viatura-text-muted);
	margin-bottom: 4px;
}

.mc-viatura-contact-field .req {
	color: var(--mc-viatura-primary);
	margin-left: 2px;
}

.mc-viatura-contact-field input,
.mc-viatura-contact-field textarea {
	display: block;
	width: 100%;
	border: none;
	border-bottom: 1.5px solid var(--mc-viatura-border);
	padding: 8px 0;
	font-size: 15px;
	font-family: inherit;
	color: var(--mc-viatura-text);
	background: transparent;
	border-radius: 0;
	box-shadow: none;
	transition: border-color 0.15s;
	outline: none;
}

.mc-viatura-contact-field input:focus,
.mc-viatura-contact-field textarea:focus {
	border-bottom-color: var(--mc-viatura-primary);
}

.mc-viatura-contact-field textarea {
	resize: vertical;
	min-height: 70px;
}

.mc-viatura-contact-field.has-error input,
.mc-viatura-contact-field.has-error textarea {
	border-bottom-color: #a8200a;
}

.mc-viatura-contact-field-error {
	font-size: 12px;
	color: #a8200a;
	margin: 4px 0 0;
}

/* Row de telefone + email */
.mc-viatura-contact-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

@media (max-width: 480px) {
	.mc-viatura-contact-row {
		grid-template-columns: 1fr;
		gap: 0;
	}
}

/* RGPD */
.mc-viatura-contact-rgpd {
	margin: 22px 0 20px;
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
	line-height: 1.5;
}

.mc-viatura-contact-rgpd label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
}

.mc-viatura-contact-rgpd input[type="checkbox"] {
	flex-shrink: 0;
	margin-top: 2px;
	width: 16px;
	height: 16px;
	accent-color: var(--mc-viatura-primary);
}

.mc-viatura-contact-rgpd a {
	color: var(--mc-viatura-primary);
	text-decoration: underline;
}

.mc-viatura-contact-rgpd.has-error {
	color: #a8200a;
}

/* Feedback messages */
.mc-viatura-contact-feedback {
	font-size: 13px;
	padding: 10px 12px;
	border-radius: 6px;
	margin-bottom: 14px;
	display: none;
	line-height: 1.4;
}

.mc-viatura-contact-feedback.is-info {
	display: block;
	background: #f0f6fc;
	color: #1d4d7c;
}

.mc-viatura-contact-feedback.is-success {
	display: block;
	background: #edf7ed;
	color: #0a4f1d;
	font-weight: 500;
}

.mc-viatura-contact-feedback.is-error {
	display: block;
	background: #fcecea;
	color: #6c1606;
}

/* Submit button — usa o mesmo .mc-viatura-btn--primary mas full width */
.mc-viatura-contact-submit {
	width: 100%;
	padding: 14px 20px;
	font-size: 15px;
}

.mc-viatura-contact-submit.is-busy {
	opacity: 0.7;
	cursor: wait;
}

/* Body lock quando modal aberto */
body.mc-viatura-modal-open {
	overflow: hidden;
}

/* Mobile adjustments */
@media (max-width: 480px) {
	.mc-viatura-contact-card {
		padding: 28px 22px 22px;
	}

	.mc-viatura-contact-header h2 {
		font-size: 22px;
	}
}

/* ============================================================================
 * M7a-patch3 — Ajustes UX/visual
 *
 * 1. Preço inline com IVA flags (em vez de stacked vertical)
 * 2. Badges (etiquetas) com dot animado pulse
 * 3. Overlay diagonal VENDIDO sobre galeria
 * 4. Thumbnails encolhidos (1px border) com alinhamento mais tight
 * ============================================================================ */

/* --- 1. Preço inline --- */

.mc-viatura-preco-block {
	flex-direction: row;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 10px;
}

.mc-viatura-preco {
	line-height: 1;
}

.mc-viatura-iva-flags {
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
	font-weight: 500;
}

/* --- 2. Badges com dot animado pulse --- */

.mc-viatura-etiqueta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	position: relative;
}

.mc-viatura-etiqueta::before {
	content: '';
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #fff;
	display: inline-block;
	animation: mc-viatura-badge-pulse 1.6s ease-in-out infinite;
}

@keyframes mc-viatura-badge-pulse {
	0%, 100% {
		opacity: 1;
		transform: scale(1);
		box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.7);
	}
	50% {
		opacity: 0.8;
		transform: scale(1.15);
		box-shadow: 0 0 0 4px rgba(255, 255, 255, 0);
	}
}

/* --- 3. Vendido overlay diagonal --- */

.mc-viatura-gallery {
	position: relative;
}

.mc-viatura-gallery.is-sold .mc-viatura-gallery-main {
	position: relative;
}

.mc-viatura-gallery.is-sold .mc-viatura-gallery-main::after {
	/* Dim a foto principal em modo vendido */
	content: '';
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.25);
	pointer-events: none;
	z-index: 1;
	border-radius: var(--mc-viatura-radius);
}

.mc-viatura-gallery-sold-banner {
	position: absolute;
	top: 28px;
	right: -52px;
	background: var(--mc-viatura-primary);
	color: #fff;
	padding: 8px 70px;
	font-weight: 800;
	font-size: 14px;
	letter-spacing: 0.18em;
	transform: rotate(40deg);
	transform-origin: center;
	z-index: 5;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
	pointer-events: none;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
}

/* No card de related, badge vendido fica top-right horizontal (menos espaço) */
.mc-viatura-card .mc-viatura-card-estado[class*="vendido"] {
	background: var(--mc-viatura-primary);
	color: #fff;
}

/* --- 4. Thumbnails encolhidos + tight --- */

.mc-viatura-single .mc-viatura-gallery-thumbs {
	gap: 6px;
	margin-top: 6px;
}

.mc-viatura-single .mc-viatura-gallery-thumb,
.mc-viatura-single .mc-viatura-gallery-thumb:hover,
.mc-viatura-single .mc-viatura-gallery-thumb:focus {
	border-width: 1px;
	border-radius: 4px;
}

.mc-viatura-single .mc-viatura-gallery-thumb {
	border-color: transparent;
	box-shadow: inset 0 0 0 0.5px rgba(0, 0, 0, 0.04);
}

.mc-viatura-single .mc-viatura-gallery-thumb:hover {
	border-color: var(--mc-viatura-border);
	box-shadow: inset 0 0 0 0.5px rgba(0, 0, 0, 0.04);
}

.mc-viatura-single .mc-viatura-gallery-thumb.is-active {
	border-color: var(--mc-viatura-primary);
	box-shadow: inset 0 0 0 1px var(--mc-viatura-primary), 0 0 0 2px rgba(229, 37, 40, 0.12);
}

/* --- Container da galeria: clip overflow para conter o banner diagonal --- */

.mc-viatura-gallery {
	overflow: hidden;
	border-radius: var(--mc-viatura-radius);
}

.mc-viatura-gallery-main {
	margin-bottom: 8px;
}

/* Em mobile, banner mais pequeno */
@media (max-width: 720px) {
	.mc-viatura-gallery-sold-banner {
		top: 18px;
		right: -56px;
		padding: 6px 70px;
		font-size: 12px;
	}
}

/* ============================================================================
 * M7a-patch4 — Pulse no dot do estado pill (todos os estados)
 *
 * Aplica-se a Disponível, Reservado, Brevemente, Vendido — usa a cor do
 * próprio estado (--estado-color setado inline no markup) via color-mix
 * para o ripple shadow.
 * ============================================================================ */

.mc-viatura-estado-pill .dot {
	animation: mc-viatura-estado-pulse 1.6s ease-in-out infinite;
}

@keyframes mc-viatura-estado-pulse {
	0%, 100% {
		transform: scale(1);
		box-shadow: 0 0 0 0 color-mix(in srgb, var(--estado-color, #787c82) 55%, transparent);
	}
	50% {
		transform: scale(1.2);
		box-shadow: 0 0 0 5px color-mix(in srgb, var(--estado-color, #787c82) 0%, transparent);
	}
}

/* Fallback para browsers sem color-mix: pulse só via scale + opacity (sem ripple coloured) */
@supports not (background: color-mix(in srgb, red, transparent)) {
	@keyframes mc-viatura-estado-pulse {
		0%, 100% { transform: scale(1); opacity: 1; }
		50%      { transform: scale(1.2); opacity: 0.7; }
	}
}

/* Respeitar prefers-reduced-motion — desliga animação para utilizadores
   que preferem ecrãs mais calmos */
@media (prefers-reduced-motion: reduce) {
	.mc-viatura-estado-pill .dot,
	.mc-viatura-etiqueta::before {
		animation: none;
	}
}

/* ============================================================================
 * M8 — Simulador de Crédito
 *
 * Modal full-screen (mesmo padrão visual do modal de contacto) com sliders
 * para entrada e prazo, resultado destacado e CTA para pedir proposta.
 * ============================================================================ */

.mc-viatura-simulador {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

.mc-viatura-simulador[hidden] {
	display: none;
}

.mc-viatura-simulador-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

.mc-viatura-simulador-card {
	position: relative;
	background: #fff;
	border-radius: var(--mc-viatura-radius);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	max-width: 540px;
	width: 100%;
	max-height: 92vh;
	overflow-y: auto;
	padding: 28px;
	animation: mc-viatura-simulador-in 0.24s ease-out;
}

@keyframes mc-viatura-simulador-in {
	from { opacity: 0; transform: translateY(20px) scale(0.97); }
	to   { opacity: 1; transform: translateY(0)    scale(1); }
}

.mc-viatura-simulador-close {
	position: absolute;
	top: 12px;
	right: 14px;
	width: 32px;
	height: 32px;
	border: 0;
	background: transparent;
	color: var(--mc-viatura-text-muted);
	font-size: 28px;
	line-height: 1;
	cursor: pointer;
	border-radius: 50%;
	transition: background 0.15s, color 0.15s;
}

/* Specificity bump para vencer o reset.css do Hello Elementor que define
   button:hover { background-color: #CC3366; color: #fff }.
   Selectors do reset têm specificity (0,2,0) por [type="button"]:hover;
   prefix .mc-viatura-simulador sobe-nos para (0,3,0). */
.mc-viatura-simulador .mc-viatura-simulador-close {
	background-color: transparent;
	color: var(--mc-viatura-text-muted);
}

.mc-viatura-simulador .mc-viatura-simulador-close:hover,
.mc-viatura-simulador .mc-viatura-simulador-close:focus {
	background-color: rgba(0, 0, 0, 0.06);
	color: var(--mc-viatura-text);
}

.mc-viatura-simulador-header {
	margin-bottom: 22px;
	padding-right: 36px;
}

.mc-viatura-simulador-header h2 {
	margin: 0 0 4px;
	font-size: 22px;
	font-weight: 700;
	color: var(--mc-viatura-text);
}

.mc-viatura-simulador-subtitle {
	margin: 0;
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
}

.mc-viatura-simulador-body {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

/* --- Linha valor da viatura --- */

.mc-viatura-simulador-valor {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: 14px 16px;
	background: #f6f7f9;
	border-radius: 6px;
}

.mc-viatura-simulador-row-label {
	font-size: 13px;
	color: var(--mc-viatura-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.mc-viatura-simulador-row-value {
	font-size: 18px;
	font-weight: 700;
	color: var(--mc-viatura-text);
}

/* --- Controlos (entrada + prazo) --- */

.mc-viatura-simulador-control {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.mc-viatura-simulador-control-label {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	font-size: 14px;
	font-weight: 600;
	color: var(--mc-viatura-text);
}

.mc-viatura-simulador-control-value {
	font-weight: 700;
	color: var(--mc-viatura-primary);
}

.mc-viatura-simulador-control-value .mc-sim-entrada-pct {
	color: var(--mc-viatura-text-muted);
	font-weight: 500;
	margin-left: 4px;
}

.mc-viatura-simulador-range {
	width: 100%;
	margin: 8px 0 2px;
	accent-color: var(--mc-viatura-primary);
	cursor: pointer;
}

/* Webkit thumb */
.mc-viatura-simulador-range::-webkit-slider-thumb {
	cursor: grab;
}
.mc-viatura-simulador-range:active::-webkit-slider-thumb {
	cursor: grabbing;
}

.mc-viatura-simulador-range-ticks {
	display: flex;
	justify-content: space-between;
	font-size: 11px;
	color: var(--mc-viatura-text-muted);
	padding: 0 4px;
}

/* --- Resultado --- */

.mc-viatura-simulador-result {
	background: linear-gradient(135deg, rgba(229, 37, 40, 0.04), rgba(229, 37, 40, 0.08));
	border: 1px solid rgba(229, 37, 40, 0.15);
	border-radius: 8px;
	padding: 18px 20px;
}

.mc-viatura-simulador-result-main {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	margin-bottom: 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.mc-viatura-simulador-result-label {
	font-size: 12px;
	color: var(--mc-viatura-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.mc-viatura-simulador-result-monthly {
	font-size: 32px;
	font-weight: 800;
	color: var(--mc-viatura-primary);
	line-height: 1.1;
	display: flex;
	align-items: baseline;
	gap: 4px;
}

.mc-sim-monthly-suffix {
	font-size: 14px;
	font-weight: 500;
	color: var(--mc-viatura-text-muted);
}

.mc-viatura-simulador-result-meta {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 8px;
	text-align: center;
}

.mc-viatura-simulador-result-meta .cell {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.mc-viatura-simulador-result-meta .lbl {
	font-size: 11px;
	color: var(--mc-viatura-text-muted);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.mc-viatura-simulador-result-meta .val {
	font-size: 14px;
	font-weight: 700;
	color: var(--mc-viatura-text);
}

.mc-viatura-simulador-offer-applied,
.mc-viatura-simulador-no-offer {
	margin: 12px 0 0;
	font-size: 12px;
	color: var(--mc-viatura-text-muted);
	text-align: center;
}

.mc-viatura-simulador-offer-applied .lbl {
	font-weight: 600;
}

.mc-viatura-simulador-offer-applied .mc-sim-offer-label {
	font-weight: 700;
	color: var(--mc-viatura-primary);
}

/* --- Disclaimer --- */

.mc-viatura-simulador-disclaimer {
	font-size: 11px;
	line-height: 1.55;
	color: var(--mc-viatura-text-muted);
	padding: 12px 14px;
	background: #fafafa;
	border-radius: 6px;
	border-left: 3px solid #dcdcde;
}

.mc-viatura-simulador-disclaimer p {
	margin: 0;
}

.mc-viatura-simulador-disclaimer p + p {
	margin-top: 6px;
}

/* --- CTA --- */

.mc-viatura-simulador-request {
	width: 100%;
	margin-top: 4px;
}

.mc-viatura-simulador-request:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

/* --- Body lock quando modal aberto --- */

body.mc-viatura-modal-open {
	overflow: hidden;
}

/* --- Mobile --- */

@media (max-width: 540px) {
	.mc-viatura-simulador {
		padding: 0;
	}
	.mc-viatura-simulador-card {
		max-width: 100%;
		max-height: 100vh;
		border-radius: 0;
		padding: 22px 18px;
	}
	.mc-viatura-simulador-result-monthly {
		font-size: 28px;
	}
}

/* ============================================================================
 * M6-patch4 — Logo da marca no hero (substitui texto da marca quando existe)
 * ============================================================================ */

.mc-viatura-marca--logo {
	margin: 0 0 12px;
	line-height: 1;
}

.mc-viatura-marca-logo-img {
	max-height: 42px;
	max-width: 140px;
	width: auto;
	height: auto;
	object-fit: contain;
	display: block;
}

@media (max-width: 720px) {
	.mc-viatura-marca-logo-img {
		max-height: 36px;
		max-width: 120px;
	}
}

/* ============================================================================
 * M6-patch6 — Specs grid: eliminar cell cinzenta vazia
 *
 * Problema: o trick `gap: 1px + background: var(--border-light)` no grid
 * container cria um fundo cinza que fica visível nas cells "vazias" do grid
 * (slots criados pelo auto-fit mas sem item DOM). auto-fit só colapsa
 * COLUNAS inteiras vazias; cells parciais (última row incompleta) ficam.
 *
 * Solução: substituir o gap+bg trick por `box-shadow inset` nas cells reais.
 * Cells reais (.mc-viatura-spec) têm divisórias internas via box-shadow.
 * Cells vazias do grid não têm elemento DOM → não têm shadow nem bg →
 * ficam transparentes (mostram o fundo da página).
 * ============================================================================ */

.mc-viatura-specs-grid {
	gap: 0;
	background: transparent;
}

.mc-viatura-spec {
	/* Divisórias internas via box-shadow inset (não somam à width).
	   Última col fica com shadow-right "absorvido" pelo border do container;
	   última row idem com shadow-bottom. */
	box-shadow:
		inset -1px 0 0 var(--mc-viatura-border-light),
		inset 0 -1px 0 var(--mc-viatura-border-light);
}

/* ============================================================================
 * M5-patch1 — Preço oculto quando viatura está Vendida
 *
 * No hero, substitui o bloco de preço por uma etiqueta "Viatura Vendida".
 * Nos cards related, o preço é substituído por "Vendida" em vermelho neon.
 * ============================================================================ */

.mc-viatura-preco-block--vendido {
	display: flex;
	align-items: center;
	gap: 8px;
}

.mc-viatura-preco-vendido {
	display: inline-block;
	padding: 8px 18px;
	border-radius: 6px;
	background: var(--mc-viatura-vendido-bg, #fbeeee);
	color: var(--mc-viatura-vendido-fg, #a8200a);
	font-size: 22px;
	font-weight: 700;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	border: 1.5px solid var(--mc-viatura-vendido-fg, #a8200a);
}

.mc-viatura-card-preco .vendido {
	color: var(--mc-viatura-vendido-fg, #a8200a);
	font-weight: 700;
	letter-spacing: 0.3px;
	text-transform: uppercase;
}

/* ============================================================================
 * Coerência com a listagem do stand — eyebrow LED + badges
 * ========================================================================== */

@keyframes mc-viatura-led {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.35; }
}

/* Marca (variante texto) com barra LED vermelha, igual aos cards */
.mc-viatura-marca:not(.mc-viatura-marca--logo) {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	line-height: 1;
}

.mc-viatura-marca:not(.mc-viatura-marca--logo)::before {
	content: "";
	width: 3px;
	height: 12px;
	border-radius: 2px;
	background: var(--mc-viatura-primary);
	animation: mc-viatura-led 1.8s ease-in-out infinite;
}

/* IVA Dedutível como badge preto junto ao preço */
.mc-viatura-iva-badge {
	display: inline-flex;
	align-items: center;
	align-self: center;
	padding: 3px 9px;
	border-radius: 6px;
	background: #0F1216;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	line-height: 1.4;
}

/* Tags Caixa / Elétrico sobre a base da imagem da galeria */
.mc-viatura-gallery-tags {
	position: absolute;
	left: 16px;
	bottom: 16px;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	z-index: 3;
	pointer-events: none;
}

.mc-viatura-gallery-tag {
	display: inline-flex;
	align-items: center;
	padding: 5px 12px;
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	line-height: 1.3;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.mc-viatura-gallery-tag--caixa {
	background: #0F1216;
	color: #fff;
}

.mc-viatura-gallery-tag--eco {
	background: #2ce64a;
	color: #fff;
}

/* Tags (Caixa / Elétrico) nos cards de viaturas semelhantes */
.mc-viatura-card-capa {
	background: #0F1216;
}

.mc-viatura-card-tags {
	position: absolute;
	left: 10px;
	bottom: 10px;
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	z-index: 2;
	pointer-events: none;
	max-width: calc(100% - 20px);
}

.mc-viatura-card-tag {
	display: inline-flex;
	align-items: center;
	padding: 3px 8px;
	border-radius: 999px;
	font-size: 9.5px;
	font-weight: 700;
	letter-spacing: 0.3px;
	text-transform: uppercase;
	line-height: 1.3;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.mc-viatura-card-tag--caixa {
	background: #0F1216;
	color: #fff;
}

.mc-viatura-card-tag--eco {
	background: #2ce64a;
	color: #fff;
}
