/**
 * Single Vehicle & Lightbox Styles — Moto Deal Fribourg
 * Loaded conditionally on single vehicle pages (/motos/{slug}).
 */

/* ==========================================================================
   Single Vehicle — Fiche détail
   ========================================================================== */

.mdf-single-vehicule {
	padding-bottom: var(--space-xl);
}

/* Override Kadence wrapper padding on single vehicle */
.single-vehicule .site #inner-wrap,
.single-vehicule .content-area,
.single-vehicule .entry-content-wrap,
.single-vehicule .content-wrap {
	padding-left: 0;
	padding-right: 0;
	max-width: none;
}

/* Tighter container padding on mobile */
.mdf-single-vehicule .mdf-container {
	padding-left: var(--space-md);
	padding-right: var(--space-md);
}

@media (min-width: 48em) {
	.mdf-single-vehicule .mdf-container {
		padding-left: var(--space-lg);
		padding-right: var(--space-lg);
	}
}

/* --- Breadcrumb --- */

.mdf-breadcrumb {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-md) 0;
	font-size: 0.875rem;
	color: var(--color-muted);
	flex-wrap: wrap;
}

.mdf-breadcrumb a {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	color: var(--color-muted);
	transition: color var(--transition-fast);
}

.mdf-breadcrumb a:hover {
	color: var(--color-accent);
}

.mdf-breadcrumb__sep {
	color: var(--color-border);
}

.mdf-breadcrumb__current {
	color: var(--color-text);
	font-weight: 500;
}

/* --- Two-column grid --- */

.mdf-single__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md);
	margin-bottom: var(--space-xl);
}

@media (min-width: 48em) {
	.mdf-single__grid {
		gap: var(--space-lg);
	}
}

@media (min-width: 64em) {
	.mdf-single__grid {
		grid-template-columns: 1fr 400px;
		gap: var(--space-xl);
	}
}

@media (min-width: 80em) {
	.mdf-single__grid {
		grid-template-columns: 1fr 440px;
	}
}

/* ==========================================================================
   Single Vehicle — Gallery
   ========================================================================== */

.mdf-gallery__main {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 3;
	background-color: var(--color-surface);
	border-radius: 0;
	overflow: hidden;
	cursor: zoom-in;
	/* Edge-to-edge on mobile */
	margin-left: calc(-1 * var(--space-md));
	margin-right: calc(-1 * var(--space-md));
	width: calc(100% + 2 * var(--space-md));
}

@media (min-width: 48em) {
	.mdf-gallery__main {
		border-radius: var(--radius-lg);
		margin-left: 0;
		margin-right: 0;
		width: 100%;
	}
}

.mdf-gallery__main img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: opacity var(--transition-base);
}

.mdf-gallery__main--placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-md);
	color: var(--color-muted);
	cursor: default;
}

/* Gallery nav arrows */
.mdf-gallery__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: rgba(0, 0, 0, 0.6);
	border: none;
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	transition: background-color var(--transition-fast);
	z-index: 5;
}

.mdf-gallery__nav:hover {
	background-color: rgba(0, 0, 0, 0.85);
}

.mdf-gallery__nav--prev {
	left: 12px;
}

.mdf-gallery__nav--next {
	right: 12px;
}

/* Counter badge */
.mdf-gallery__counter {
	position: absolute;
	bottom: 12px;
	right: 12px;
	padding: 4px 10px;
	background-color: rgba(0, 0, 0, 0.6);
	color: #fff;
	font-size: 0.8125rem;
	font-weight: 500;
	border-radius: 100px;
	z-index: 5;
}

/* Thumbnails strip */
.mdf-gallery__thumbs {
	display: flex;
	gap: 8px;
	margin-top: var(--space-sm);
	overflow-x: auto;
	padding-bottom: 4px;
	scrollbar-width: thin;
	scrollbar-color: var(--color-border) transparent;
}

.mdf-gallery__thumb {
	flex-shrink: 0;
	width: 72px;
	height: 54px;
	border-radius: var(--radius-sm);
	overflow: hidden;
	border: 2px solid transparent;
	cursor: pointer;
	opacity: 0.6;
	transition: all var(--transition-fast);
	padding: 0;
	background: none;
}

.mdf-gallery__thumb:hover {
	opacity: 0.9;
	border-color: var(--color-border);
}

.mdf-gallery__thumb--active {
	opacity: 1;
	border-color: var(--color-accent);
}

.mdf-gallery__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ==========================================================================
   Single Vehicle — Info sidebar
   ========================================================================== */

.mdf-single__info {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	min-width: 0;
	width: 100%;
}

/* Force all direct children to fill sidebar width */
.mdf-single__info > * {
	width: 100%;
	box-sizing: border-box;
}

@media (min-width: 48em) {
	.mdf-single__info {
		gap: var(--space-md);
	}
}

@media (min-width: 64em) {
	.mdf-single__info {
		position: sticky;
		top: var(--space-lg);
		align-self: start;
	}
}

/* Badges row */
.mdf-single__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

/* Brand label */
.mdf-single__brand {
	color: var(--color-accent);
	font-family: var(--font-heading);
	font-size: 0.8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

/* Title */
.mdf-single__title {
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1.2;
	margin: 0;
}

@media (min-width: 48em) {
	.mdf-single__title {
		font-size: 2rem;
	}
}

/* Key specs (inline pills) */
.mdf-single__key-specs {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.mdf-single__key-spec {
	display: inline-block;
	padding: 4px 10px;
	background-color: var(--color-surface-2);
	border-radius: var(--radius-sm);
	color: var(--color-muted);
	font-size: 0.8125rem;
	font-weight: 500;
}

/* Price */
.mdf-single__price {
	display: flex;
	align-items: baseline;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.mdf-single__price-main {
	font-size: 2rem;
}

@media (min-width: 48em) {
	.mdf-single__price-main {
		font-size: 2.25rem;
	}
}

/* Divider */
.mdf-single__divider {
	border: none;
	border-top: 1px solid var(--color-border);
	margin: 0;
}

/* Specs table — full width to match CTA buttons */
.mdf-specs-table {
	display: table;
	width: 100% !important;
	min-width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-sizing: border-box;
}

.mdf-specs-table tr {
	border-bottom: 1px solid var(--color-border);
}

.mdf-specs-table tr:last-child {
	border-bottom: none;
}

.mdf-specs-table th,
.mdf-specs-table td {
	padding: 10px 14px;
	font-size: 0.875rem;
	vertical-align: top;
}

.mdf-specs-table th {
	color: var(--color-muted);
	font-weight: 400;
	text-align: left;
	width: 40%;
}

.mdf-specs-table td {
	color: var(--color-text);
	font-weight: 500;
	text-align: right;
}

/* CTA buttons */
.mdf-single__cta {
	margin-top: var(--space-sm);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.mdf-single__cta-btn {
	width: 100%;
	max-width: 100%;
	justify-content: center;
	box-sizing: border-box;
}

.mdf-single__sold-notice {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
	padding: var(--space-md);
	background-color: rgba(107, 107, 107, 0.1);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: var(--color-muted);
	font-family: var(--font-heading);
	font-size: 0.9375rem;
	font-weight: 700;
	text-transform: uppercase;
}

/* MotoScout link */
.mdf-single__ms-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--color-muted);
	font-size: 0.875rem;
	font-weight: 500;
	transition: color var(--transition-fast);
}

.mdf-single__ms-link:hover {
	color: var(--color-accent);
}

/* ==========================================================================
   Single Vehicle — Description & Tech specs (full width)
   ========================================================================== */

.mdf-single__details {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-lg);
	margin-bottom: var(--space-xl);
	padding-top: var(--space-xl);
	border-top: 1px solid var(--color-border);
}

@media (min-width: 48em) {
	.mdf-single__details {
		grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	}
}

.mdf-single__section {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-lg);
}

.mdf-single__section-title {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0 0 var(--space-md);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--color-border);
}

.mdf-single__content {
	color: var(--color-text);
	font-size: 0.9375rem;
	line-height: 1.7;
}

.mdf-single__content p {
	margin-bottom: var(--space-md);
}

.mdf-single__content p:last-child {
	margin-bottom: 0;
}

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

.mdf-lightbox {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
}

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

.mdf-lightbox__overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(0, 0, 0, 0.92);
}

.mdf-lightbox__content {
	position: relative;
	max-width: 90vw;
	max-height: 90vh;
	z-index: 1;
}

.mdf-lightbox__content img {
	max-width: 90vw;
	max-height: 85vh;
	object-fit: contain;
	border-radius: var(--radius-md);
}

.mdf-lightbox__close {
	position: absolute;
	top: -48px;
	right: 0;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	transition: all var(--transition-fast);
}

.mdf-lightbox__close:hover {
	background-color: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.4);
}

.mdf-lightbox__nav {
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: rgba(0, 0, 0, 0.5);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	transition: all var(--transition-fast);
	z-index: 2;
}

.mdf-lightbox__nav:hover {
	background-color: rgba(0, 0, 0, 0.8);
	border-color: rgba(255, 255, 255, 0.3);
}

.mdf-lightbox__nav--prev {
	left: var(--space-lg);
}

.mdf-lightbox__nav--next {
	right: var(--space-lg);
}

.mdf-lightbox__counter {
	position: absolute;
	bottom: -40px;
	left: 50%;
	transform: translateX(-50%);
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.875rem;
	font-weight: 500;
}
