/**
 * George For Hire — Plugin Public Styles
 *
 * Component styles for all plugin-rendered frontend elements.
 * BEM methodology: .gfh-<block>__<element>--<modifier>
 * Relies on theme CSS custom properties (--gfh-*).
 *
 * @package George_For_Hire
 */

/* ==========================================================================
   Hero / Booking Step 1
   ========================================================================== */

.gfh-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--gfh-charcoal, #1a1a1a);
	overflow: hidden;
}

.gfh-hero__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: blur(3px);
	transform: scale(1.05); /* compensate blur edges */
	z-index: 0;
}

@media (max-width: 768px) {
	.gfh-hero__video {
		filter: blur(2px);
	}
}

.gfh-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(13, 13, 13, 0.75) 0%,
		rgba(26, 26, 26, 0.5) 50%,
		rgba(212, 131, 47, 0.1) 100%
	);
	z-index: 1;
}

.gfh-hero__content {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 6rem 1.5rem 4rem;
	max-width: 800px;
	width: 100%;
}

.gfh-hero__title {
	color: var(--gfh-cream, #f5f0eb);
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	margin-bottom: 0.75rem;
	text-shadow: 0 2px 20px rgba(0, 0, 0, 0.4);
}

.gfh-hero__subtitle {
	color: var(--gfh-sand, #98b8b7);
	font-size: clamp(1rem, 2vw, 1.25rem);
	margin-bottom: 3rem;
	max-width: 50ch;
	margin-left: auto;
	margin-right: auto;
}

/* Step 1 form */
.gfh-booking-step1 {
	background: rgba(255, 255, 255, 0.07);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--gfh-radius-lg, 12px);
	padding: 2rem;
	max-width: 520px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.gfh-booking-step1__group {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.gfh-booking-step1__group-label {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--gfh-amber, #149898);
}

.gfh-booking-step1__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
	flex: 1;
}

.gfh-booking-step1__field label {
	color: var(--gfh-sand, #98b8b7);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 0.4rem;
}

.gfh-booking-step1__submit {
	width: 100%;
	padding: 1em;
	font-size: 1.05rem;
}

/* ==========================================================================
   Custom Picker — Trigger Buttons
   ========================================================================== */

.gfh-picker-trigger {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	width: 100%;
	padding: 0.75rem 1rem;
	background: rgba(255, 255, 255, 0.08);
	border: 2px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--gfh-radius, 6px);
	color: var(--gfh-stone, #6b6b6b);
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 0.95rem;
	cursor: pointer;
	transition: background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease;
	text-align: left;
	line-height: 1.4;
}

.gfh-picker-trigger:hover {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.22);
}

.gfh-picker-trigger--active {
	border-color: var(--gfh-amber, #149898);
	background: rgba(255, 255, 255, 0.12);
	box-shadow: 0 0 0 3px rgba(20, 152, 152, 0.2), 0 0 20px rgba(20, 152, 152, 0.08);
}

.gfh-picker-trigger--has-value {
	color: var(--gfh-cream, #f5f0eb);
}

.gfh-picker-trigger--has-value .gfh-picker-trigger__text {
	font-weight: 600;
}

.gfh-picker-trigger--error {
	border-color: var(--gfh-red, #c0392b) !important;
	box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.15) !important;
	animation: gfh-shake 0.45s ease;
}

.gfh-picker-trigger__icon {
	flex-shrink: 0;
	color: var(--gfh-sand, #98b8b7);
	opacity: 0.65;
	transition: color 0.25s ease, opacity 0.25s ease;
}

.gfh-picker-trigger--active .gfh-picker-trigger__icon,
.gfh-picker-trigger:hover .gfh-picker-trigger__icon {
	color: var(--gfh-amber, #149898);
	opacity: 1;
}

.gfh-picker-trigger__text {
	flex: 1;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

@keyframes gfh-shake {
	0%, 100% { transform: translateX(0); }
	15%  { transform: translateX(-5px); }
	30%  { transform: translateX(5px); }
	45%  { transform: translateX(-4px); }
	60%  { transform: translateX(4px); }
	75%  { transform: translateX(-2px); }
	90%  { transform: translateX(2px); }
}

/* ==========================================================================
   Custom Picker — Shared Panel Base
   ========================================================================== */

.gfh-picker-panel {
	position: absolute;
	z-index: 10000;
	background: rgba(22, 22, 22, 0.96);
	backdrop-filter: blur(24px);
	-webkit-backdrop-filter: blur(24px);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--gfh-radius-lg, 12px);
	box-shadow:
		0 20px 60px rgba(0, 0, 0, 0.5),
		0 0 0 1px rgba(255, 255, 255, 0.04) inset;
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px) scale(0.96);
	pointer-events: none;
	transition:
		opacity 0.18s ease,
		visibility 0.18s ease,
		transform 0.18s ease;
}

.gfh-picker-panel--open {
	opacity: 1;
	visibility: visible;
	transform: translateY(0) scale(1);
	pointer-events: auto;
	transition:
		opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1),
		visibility 0.3s,
		transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.gfh-picker-panel--closing {
	opacity: 0;
	visibility: hidden;
	transform: translateY(6px) scale(0.98);
	pointer-events: none;
	transition:
		opacity 0.18s ease,
		visibility 0.18s ease,
		transform 0.18s ease;
}

/* ==========================================================================
   Custom Date Picker
   ========================================================================== */

.gfh-datepicker {
	width: 300px;
	max-width: calc(100vw - 2rem);
	padding: 1.25rem;
}

.gfh-datepicker__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.gfh-datepicker__nav {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	background: none;
	border: none;
	border-radius: 50%;
	color: var(--gfh-sand, #98b8b7);
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.gfh-datepicker__nav:hover {
	background: rgba(255, 255, 255, 0.1);
	color: var(--gfh-cream, #f5f0eb);
	transform: scale(1.1);
}

.gfh-datepicker__nav:active {
	transform: scale(0.95);
}

.gfh-datepicker__month-label {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--gfh-cream, #f5f0eb);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.gfh-datepicker__weekdays {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 0;
	margin-bottom: 0.35rem;
}

.gfh-datepicker__weekdays span {
	text-align: center;
	font-size: 0.68rem;
	font-weight: 600;
	color: var(--gfh-stone, #6b6b6b);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 4px 0;
}

/* Day grid + animated month transitions */
.gfh-datepicker__grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 2px;
}

.gfh-datepicker__grid--exit-right,
.gfh-datepicker__grid--exit-left {
	opacity: 0;
	transition: opacity 0.14s ease, transform 0.14s ease;
}

.gfh-datepicker__grid--exit-right { transform: translateX(-12px); }
.gfh-datepicker__grid--exit-left  { transform: translateX(12px); }

.gfh-datepicker__grid--enter-right {
	animation: gfh-grid-slide-right 0.26s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.gfh-datepicker__grid--enter-left {
	animation: gfh-grid-slide-left 0.26s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes gfh-grid-slide-right {
	from { opacity: 0; transform: translateX(14px); }
	to   { opacity: 1; transform: translateX(0); }
}

@keyframes gfh-grid-slide-left {
	from { opacity: 0; transform: translateX(-14px); }
	to   { opacity: 1; transform: translateX(0); }
}

/* Individual day cells */
.gfh-datepicker__day {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	margin: 1px auto;
	border: none;
	border-radius: 50%;
	background: none;
	color: var(--gfh-cream, #f5f0eb);
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 0.85rem;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	animation: gfh-day-fade 0.3s ease backwards;
	animation-delay: calc(var(--day-i, 0) * 8ms);
}

@keyframes gfh-day-fade {
	from { opacity: 0; transform: scale(0.85); }
	to   { opacity: 1; transform: scale(1); }
}

.gfh-datepicker__day:hover:not(.gfh-datepicker__day--disabled):not(.gfh-datepicker__day--other) {
	background: rgba(255, 255, 255, 0.12);
	transform: scale(1.15);
}

.gfh-datepicker__day--other {
	color: rgba(255, 255, 255, 0.12);
	cursor: default;
}

.gfh-datepicker__day--disabled {
	color: rgba(255, 255, 255, 0.18);
	cursor: not-allowed;
}

.gfh-datepicker__day--disabled:hover {
	transform: none;
	background: none;
}

.gfh-datepicker__day--today:not(.gfh-datepicker__day--selected) {
	box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.18);
	font-weight: 700;
}

.gfh-datepicker__day--selected {
	background: var(--gfh-amber, #149898);
	color: #fff;
	font-weight: 700;
	box-shadow: 0 0 16px rgba(20, 152, 152, 0.45);
	transform: scale(1.1);
	animation: gfh-day-select 0.35s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes gfh-day-select {
	0%   { transform: scale(0.7); box-shadow: 0 0 0 rgba(20, 152, 152, 0); }
	50%  { transform: scale(1.2); box-shadow: 0 0 24px rgba(20, 152, 152, 0.5); }
	100% { transform: scale(1.1); box-shadow: 0 0 16px rgba(20, 152, 152, 0.4); }
}

/* ==========================================================================
   Custom Time Picker
   ========================================================================== */

.gfh-timepicker {
	width: 280px;
	max-width: calc(100vw - 2rem);
	padding: 1rem;
}

.gfh-timepicker__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 6px;
}

.gfh-timepicker__slot {
	padding: 0.55rem 0.25rem;
	border: 1px solid rgba(255, 255, 255, 0.06);
	border-radius: var(--gfh-radius, 6px);
	background: rgba(255, 255, 255, 0.04);
	color: var(--gfh-sand, #98b8b7);
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 0.82rem;
	font-weight: 500;
	text-align: center;
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	animation: gfh-chip-in 0.32s cubic-bezier(0.16, 1, 0.3, 1) backwards;
	animation-delay: calc(var(--chip-i, 0) * 18ms);
}

@keyframes gfh-chip-in {
	from {
		opacity: 0;
		transform: scale(0.8) translateY(6px);
	}
	to {
		opacity: 1;
		transform: scale(1) translateY(0);
	}
}

.gfh-timepicker__slot:hover {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.18);
	color: var(--gfh-cream, #f5f0eb);
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

.gfh-timepicker__slot--selected {
	background: var(--gfh-amber, #149898);
	border-color: var(--gfh-amber, #149898);
	color: #fff;
	font-weight: 700;
	box-shadow: 0 0 14px rgba(20, 152, 152, 0.35);
}

.gfh-timepicker__slot--selected:hover {
	background: var(--gfh-amber-dark, #0e7070);
	border-color: var(--gfh-amber-dark, #0e7070);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(20, 152, 152, 0.3);
}

/* ==========================================================================
   Trending Vehicles Slider
   ========================================================================== */

.gfh-slider {
	padding: 5rem 1.5rem;
	max-width: var(--gfh-max-width, 1280px);
	margin: 0 auto;
}

.gfh-slider__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 2rem;
}

.gfh-slider__title {
	margin: 0;
}

.gfh-slider__controls {
	display: flex;
	gap: 0.5rem;
}

.gfh-slider__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 2px solid var(--gfh-border, #e8e0d6);
	background: none;
	color: var(--gfh-charcoal, #1a1a1a);
	cursor: pointer;
	transition: background-color 200ms ease, border-color 200ms ease, color 200ms ease;
}

.gfh-slider__arrow:hover {
	background: var(--gfh-charcoal, #1a1a1a);
	border-color: var(--gfh-charcoal, #1a1a1a);
	color: var(--gfh-cream, #f5f0eb);
}

.gfh-slider__track {
	display: flex;
	gap: 1.5rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 0.5rem;
}

.gfh-slider__track::-webkit-scrollbar {
	display: none;
}

.gfh-slider__card {
	position: relative;
	flex: 0 0 280px;
	scroll-snap-align: start;
	border-radius: var(--gfh-radius-lg, 12px);
	overflow: hidden;
	background: var(--gfh-white, #faf8f5);
	box-shadow: var(--gfh-shadow, 0 2px 12px rgba(0, 0, 0, .08));
	transition: transform 200ms ease, box-shadow 200ms ease;
}

.gfh-slider__card:hover {
	transform: translateY(-4px);
	box-shadow: var(--gfh-shadow-lg, 0 8px 32px rgba(0, 0, 0, .12));
}

.gfh-slider__card-image {
	height: 180px;
	overflow: hidden;
	background: var(--gfh-dust, #e8e0d6);
}

.gfh-slider__card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 300ms ease;
}

.gfh-slider__card:hover .gfh-slider__card-image img {
	transform: scale(1.05);
}

.gfh-slider__card-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--gfh-stone, #6b6b6b);
}

.gfh-slider__card-body {
	padding: 1.25rem;
}

.gfh-slider__card-tag {
	display: inline-block;
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--gfh-amber, #149898);
	margin-bottom: 0.3rem;
}

.gfh-slider__card-title {
	font-size: 1.1rem;
	margin-bottom: 0.5rem;
}

.gfh-slider__card-price {
	display: flex;
	align-items: baseline;
	gap: 0.25rem;
}

.gfh-slider__card-price-value {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 1.5rem;
	font-weight: 900;
	color: var(--gfh-charcoal, #1a1a1a);
}

.gfh-slider__card-price-unit {
	font-size: 0.8rem;
	color: var(--gfh-stone, #6b6b6b);
}

.gfh-slider__card-link {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.gfh-slider__card-specs {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.gfh-slider__card-spec {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 0.75rem;
	color: var(--gfh-stone, #6b6b6b);
	background: var(--gfh-cream, #f5f0eb);
	padding: 0.2rem 0.5rem;
	border-radius: 4px;
}

/* "..." teaser on all cards */
.gfh-slider__card-spec--more,
.gfh-card__spec--more {
	font-weight: 700;
	font-size: 0.9rem;
	letter-spacing: 0.1em;
	color: var(--gfh-stone, #6b6b6b);
	background: transparent !important;
	padding: 0 !important;
	border-radius: 0;
}

/* ==========================================================================
   How to Rent
   ========================================================================== */

.gfh-how-to-rent {
	padding: 5rem 1.5rem;
	background: var(--gfh-bg-alt, #f5f0eb);
	text-align: center;
}

.gfh-how-to-rent__title {
	margin-bottom: 3rem;
}

.gfh-how-to-rent__steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	max-width: var(--gfh-max-width, 1280px);
	margin: 0 auto;
}

.gfh-how-to-rent__step {
	position: relative;
	padding: 2rem 1.5rem;
}

.gfh-how-to-rent__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	margin: 0 auto 1rem;
	border-radius: 50%;
	background: var(--gfh-charcoal, #1a1a1a);
	color: var(--gfh-amber, #149898);
}

.gfh-how-to-rent__number {
	display: block;
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	color: var(--gfh-amber, #149898);
	margin-bottom: 0.5rem;
}

.gfh-how-to-rent__step h3 {
	font-size: 1.1rem;
	margin-bottom: 0.5rem;
}

.gfh-how-to-rent__step p {
	font-size: 0.9rem;
	color: var(--gfh-text-muted, #6b6b6b);
	line-height: 1.5;
}

/* ==========================================================================
   Info Banner
   ========================================================================== */

.gfh-info-banner {
	background: var(--gfh-charcoal, #1a1a1a);
	padding: 4rem 1.5rem;
}

.gfh-info-banner__content {
	max-width: var(--gfh-max-width, 1280px);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
}

.gfh-info-banner__text {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: clamp(1.25rem, 3vw, 2rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	color: var(--gfh-cream, #f5f0eb);
	margin: 0;
}

.gfh-info-banner__cta {
	flex-shrink: 0;
	border-color: var(--gfh-amber, #149898);
	color: var(--gfh-amber, #149898);
}

.gfh-info-banner__cta:hover {
	background: var(--gfh-amber, #149898);
	color: var(--gfh-white, #faf8f5);
}

/* ==========================================================================
   Vehicle Picker (Step 2)
   ========================================================================== */

.gfh-vehicle-picker {
	max-width: var(--gfh-max-width, 1280px);
	margin: 0 auto;
	padding: 2rem 1.5rem 4rem;
}

.gfh-vehicle-picker__banner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: var(--gfh-bg-alt, #f5f0eb);
	border-radius: var(--gfh-radius-lg, 12px);
	padding: 1.25rem 2rem;
	margin-bottom: 2rem;
}

.gfh-vehicle-picker__banner-dates {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

.gfh-vehicle-picker__banner-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.95rem;
}

.gfh-vehicle-picker__banner-item svg {
	color: var(--gfh-amber, #149898);
	flex-shrink: 0;
}

.gfh-vehicle-picker__banner-sep {
	color: var(--gfh-stone, #6b6b6b);
}

.gfh-vehicle-picker__banner-days {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--gfh-amber, #149898);
	background: var(--gfh-charcoal, #1a1a1a);
	padding: 0.4em 1em;
	border-radius: var(--gfh-radius, 6px);
}

/* --- Required Documents Notice --- */
.gfh-docs-notice {
	display: flex;
	align-items: flex-start;
	gap: 0.875rem;
	background: var(--gfh-bg-alt, #f5f0eb);
	border-left: 4px solid var(--gfh-amber, #149898);
	border-radius: var(--gfh-radius, 6px);
	padding: 1.25rem 1.5rem;
	margin-bottom: 2rem;
}

.gfh-docs-notice__icon {
	color: var(--gfh-amber, #149898);
	flex-shrink: 0;
	margin-top: 0.1rem;
}

.gfh-docs-notice__text {
	font-size: 0.9rem;
	line-height: 1.5;
	color: var(--gfh-text, #1a1a1a);
}

.gfh-docs-notice__text strong {
	display: block;
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin-bottom: 0.25rem;
}

.gfh-docs-notice__text p {
	margin: 0;
}

.gfh-docs-notice--compact {
	padding: 1rem 1.25rem;
	margin-top: 1rem;
	margin-bottom: 0.5rem;
}

.gfh-vehicle-picker__error,
.gfh-vehicle-picker__empty {
	text-align: center;
	padding: 4rem 1.5rem;
	color: var(--gfh-text-muted, #6b6b6b);
}

.gfh-vehicle-picker__error .gfh-btn,
.gfh-vehicle-picker__empty .gfh-btn {
	margin-top: 1.5rem;
}

.gfh-vehicle-picker__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 1.5rem;
}

/* ==========================================================================
   Vehicle Card (shared between picker + catalog)
   ========================================================================== */

.gfh-card {
	position: relative;
	border-radius: var(--gfh-radius-lg, 12px);
	overflow: hidden;
	background: var(--gfh-white, #faf8f5);
	box-shadow: var(--gfh-shadow, 0 2px 12px rgba(0, 0, 0, .08));
	transition: transform 200ms ease, box-shadow 200ms ease;
}

.gfh-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--gfh-shadow-lg, 0 8px 32px rgba(0, 0, 0, .12));
}

.gfh-card__image {
	position: relative;
	height: 220px;
	overflow: hidden;
	background: var(--gfh-dust, #e8e0d6);
}

.gfh-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 300ms ease;
}

.gfh-card:hover .gfh-card__image img {
	transform: scale(1.05);
}

.gfh-card__placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--gfh-stone, #6b6b6b);
}

.gfh-card__badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	background: var(--gfh-charcoal, #1a1a1a);
	color: var(--gfh-amber, #149898);
	padding: 0.35em 0.75em;
	border-radius: var(--gfh-radius, 6px);
}

.gfh-card__body {
	padding: 1.25rem;
}

.gfh-card__title {
	font-size: 1.15rem;
	margin-bottom: 0.75rem;
}

.gfh-card__specs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}

.gfh-card__spec {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.8rem;
	color: var(--gfh-text-muted, #6b6b6b);
	background: var(--gfh-bg-alt, #f5f0eb);
	padding: 0.25em 0.6em;
	border-radius: var(--gfh-radius, 6px);
}

.gfh-card__spec svg {
	flex-shrink: 0;
}

.gfh-card__features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	margin-bottom: 1rem;
}

.gfh-card__feature {
	font-size: 0.72rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--gfh-amber-dark, #0e7070);
	background: rgba(212, 131, 47, 0.1);
	padding: 0.25em 0.5em;
	border-radius: 3px;
}

.gfh-card__footer {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	padding-top: 0.75rem;
	border-top: 1px solid var(--gfh-border, #e8e0d6);
	margin-top: 0.5rem;
}

.gfh-card__discount-badge {
	display: inline-block;
	background: var(--gfh-amber, #149898);
	color: #fff;
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	padding: 0.15em 0.55em;
	border-radius: 3px;
	margin-bottom: 0.3rem;
}

.gfh-card__price-row {
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
}

.gfh-card__price-total {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 1.75rem;
	font-weight: 900;
	color: var(--gfh-charcoal, #1a1a1a);
	line-height: 1;
}

.gfh-card__price-original {
	font-size: 1rem;
	font-weight: 500;
	color: var(--gfh-text-muted, #6b6b6b);
	text-decoration: line-through;
	line-height: 1;
}

.gfh-card__price-detail {
	display: block;
	font-size: 0.78rem;
	color: var(--gfh-text-muted, #6b6b6b);
	margin-top: 0.15rem;
}

.gfh-card__fleet {
	font-size: 0.78rem;
	color: var(--gfh-text-muted, #6b6b6b);
	white-space: nowrap;
}

.gfh-card__cta {
	flex-shrink: 0;
	font-size: 0.85rem;
	padding: 0.5em 1.25em;
}

/* ---------- Time-adjusted vehicles section ---------- */

.gfh-vehicle-picker__adjusted-section {
	margin-top: 2.5rem;
	padding-top: 2rem;
	border-top: 1px solid var(--gfh-sand, #b8a898);
}

.gfh-vehicle-picker__adjusted-heading {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1.5rem;
	color: var(--gfh-text, #1a1a1a);
}

.gfh-vehicle-picker__adjusted-heading svg {
	color: var(--gfh-amber, #d4832f);
	flex-shrink: 0;
}

.gfh-vehicle-picker__adjusted-heading h2 {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 1.25rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin: 0;
}

.gfh-card--adjusted {
	border: 1px solid var(--gfh-amber, #d4832f);
}

.gfh-card__adjustment {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.6rem 1rem;
	background: color-mix(in srgb, var(--gfh-amber, #d4832f) 10%, transparent);
	font-size: 0.82rem;
	line-height: 1.4;
	color: var(--gfh-text, #1a1a1a);
}

.gfh-card__adjustment svg {
	color: var(--gfh-amber, #d4832f);
	flex-shrink: 0;
}

.gfh-card__adjustment strong {
	color: var(--gfh-amber, #d4832f);
	font-weight: 700;
}

.gfh-card__adjustment s {
	opacity: 0.55;
}

/* ==========================================================================
   Booking Form (Step 3)
   ========================================================================== */

.gfh-booking-form {
	max-width: 800px;
	margin: 0 auto;
	padding: 2rem 1.5rem 4rem;
}

.gfh-booking-form__error {
	text-align: center;
	padding: 4rem 0;
	color: var(--gfh-text-muted, #6b6b6b);
}

.gfh-booking-form__error .gfh-btn {
	margin-top: 1.5rem;
}

.gfh-booking-form__summary {
	display: flex;
	gap: 2rem;
	background: var(--gfh-bg-alt, #f5f0eb);
	border-radius: var(--gfh-radius-lg, 12px);
	overflow: hidden;
	margin-bottom: 2.5rem;
}

.gfh-booking-form__photo {
	width: 280px;
	height: auto;
	object-fit: cover;
	flex-shrink: 0;
}

.gfh-booking-form__details {
	padding: 1.5rem 1.5rem 1.5rem 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.gfh-booking-form__category {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--gfh-amber, #149898);
}

.gfh-booking-form__vehicle-name {
	font-size: 1.5rem;
	margin: 0.25rem 0 0.75rem;
}

.gfh-booking-form__dates {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.9rem;
	color: var(--gfh-text-muted, #6b6b6b);
	margin-bottom: 0.75rem;
}

.gfh-booking-form__dates svg {
	flex-shrink: 0;
}

.gfh-booking-form__total {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 2rem;
	font-weight: 900;
	color: var(--gfh-charcoal, #1a1a1a);
}

.gfh-booking-form__breakdown {
	display: block;
	font-size: 0.85rem;
	color: var(--gfh-text-muted, #6b6b6b);
}

.gfh-booking-form__heading {
	margin-bottom: 1.5rem;
}

.gfh-booking-form__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.gfh-booking-form__field {
	margin-bottom: 1.25rem;
}

.gfh-booking-form__gdpr {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	margin: 1.5rem 0;
	font-size: 0.9rem;
	cursor: pointer;
}

.gfh-booking-form__gdpr input[type="checkbox"] {
	width: auto;
	margin-top: 0.2em;
	accent-color: var(--gfh-amber, #149898);
}

.gfh-booking-form__actions {
	margin-top: 1rem;
}

.gfh-booking-form__actions .gfh-btn {
	width: 100%;
	padding: 1em;
	font-size: 1.05rem;
}

.gfh-booking-form__error-msg {
	margin-top: 1rem;
	padding: 0.75rem 1rem;
	background: rgba(192, 57, 43, 0.08);
	border: 1px solid rgba(192, 57, 43, 0.2);
	border-radius: var(--gfh-radius, 6px);
	color: var(--gfh-red, #c0392b);
	font-size: 0.9rem;
}

.gfh-booking-form__confirmation {
	text-align: center;
	padding: 4rem 1.5rem;
}

.gfh-booking-form__confirmation svg {
	margin-bottom: 1.5rem;
}

.gfh-booking-form__confirmation h2 {
	margin-bottom: 1rem;
}

.gfh-booking-form__confirmation p {
	color: var(--gfh-text-muted, #6b6b6b);
	margin-bottom: 0.5rem;
}

.gfh-booking-form__confirmation .gfh-btn {
	margin-top: 2rem;
}

/* ==========================================================================
   Catalog Page
   ========================================================================== */

.gfh-catalog {
	max-width: var(--gfh-max-width, 1280px);
	margin: 0 auto;
	padding: 2rem 1.5rem 4rem;
}

.gfh-catalog__header {
	text-align: center;
	margin-bottom: 2.5rem;
}

.gfh-catalog__title {
	margin-bottom: 0.5rem;
}

.gfh-catalog__subtitle {
	color: var(--gfh-text-muted, #6b6b6b);
	font-size: 1.05rem;
}

.gfh-catalog__filters {
	display: flex;
	align-items: flex-end;
	gap: 1rem;
	padding: 1.5rem;
	background: var(--gfh-bg-alt, #f5f0eb);
	border-radius: var(--gfh-radius-lg, 12px);
	margin-bottom: 2rem;
	flex-wrap: wrap;
}

.gfh-catalog__filter {
	flex: 1;
	min-width: 150px;
}

.gfh-catalog__filter label {
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--gfh-text-muted, #6b6b6b);
}

.gfh-catalog__filter-btn {
	flex-shrink: 0;
	align-self: flex-end;
}

.gfh-catalog__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 1.5rem;
}

.gfh-catalog__empty {
	text-align: center;
	padding: 4rem 1.5rem;
	color: var(--gfh-text-muted, #6b6b6b);
	grid-column: 1 / -1;
}

.gfh-catalog__cta {
	text-align: center;
	margin-top: 3rem;
	padding: 2.5rem;
	background: var(--gfh-bg-alt, #f5f0eb);
	border-radius: var(--gfh-radius-lg, 12px);
}

.gfh-catalog__cta p {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 1.5rem;
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: 1rem;
}

/* ==========================================================================
   Contact Page
   ========================================================================== */

.gfh-contact {
	max-width: var(--gfh-max-width, 1280px);
	margin: 0 auto;
	padding: 2rem 1.5rem 4rem;
}

.gfh-contact__header {
	text-align: center;
	margin-bottom: 3rem;
}

.gfh-contact__title {
	margin-bottom: 0.5rem;
}

.gfh-contact__subtitle {
	color: var(--gfh-text-muted, #6b6b6b);
	font-size: 1.05rem;
}

.gfh-contact__grid {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 3rem;
}

.gfh-contact__info h3 {
	font-size: 1.25rem;
	margin-bottom: 1.5rem;
}

.gfh-contact__info-item {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 1rem;
	font-size: 0.95rem;
}

.gfh-contact__info-item svg {
	flex-shrink: 0;
	color: var(--gfh-amber, #149898);
	margin-top: 0.15rem;
}

.gfh-contact__info-item a {
	color: var(--gfh-text, #1a1a1a);
}

.gfh-contact__info-item a:hover {
	color: var(--gfh-amber, #149898);
}

.gfh-contact__map {
	margin-top: 2rem;
	border-radius: var(--gfh-radius-lg, 12px);
	overflow: hidden;
}

.gfh-contact__map iframe {
	width: 100%;
	height: 250px;
	border: 0;
}

.gfh-contact__form-wrap {
	background: var(--gfh-bg-alt, #f5f0eb);
	border-radius: var(--gfh-radius-lg, 12px);
	padding: 2rem;
}

.gfh-contact__field {
	margin-bottom: 1.25rem;
}

.gfh-contact__success {
	text-align: center;
	padding: 3rem 1.5rem;
}

.gfh-contact__success svg {
	margin-bottom: 1rem;
}

.gfh-contact__success h3 {
	margin-bottom: 0.5rem;
}

.gfh-contact__success p {
	color: var(--gfh-text-muted, #6b6b6b);
}

.gfh-contact__error {
	margin-bottom: 1.5rem;
	padding: 0.75rem 1rem;
	background: rgba(192, 57, 43, 0.08);
	border: 1px solid rgba(192, 57, 43, 0.2);
	border-radius: var(--gfh-radius, 6px);
	color: var(--gfh-red, #c0392b);
	font-size: 0.9rem;
}

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

@media (max-width: 768px) {
	.gfh-hero {
		min-height: 100svh;
	}

	.gfh-hero__content {
		padding: 5rem 1rem 3rem;
	}

	.gfh-hero__subtitle {
		margin-bottom: 1.5rem;
	}

	.gfh-booking-step1 {
		padding: 0.85rem;
		border-radius: var(--gfh-radius, 6px);
		gap: 0.6rem;
	}

	.gfh-booking-step1__group {
		flex-direction: column;
		align-items: stretch;
		gap: 0.35rem;
	}

	.gfh-booking-step1__group-label {
		font-size: 0.7rem;
	}

	.gfh-booking-step1__row {
		gap: 0.5rem;
	}

	.gfh-booking-step1__field label {
		font-size: 0.7rem;
		letter-spacing: 0.08em;
		margin-bottom: 0.2rem;
	}

	.gfh-picker-trigger {
		padding: 0.55rem 0.7rem;
		font-size: 0.9rem;
		gap: 0.5rem;
		border-width: 1.5px;
	}

	.gfh-picker-trigger__icon {
		width: 16px;
		height: 16px;
	}

	.gfh-booking-step1__submit {
		padding: 0.75em;
		font-size: 0.9rem;
	}

	.gfh-booking-step1__submit svg {
		width: 17px;
		height: 17px;
	}

	.gfh-datepicker {
		width: 280px;
	}

	.gfh-timepicker {
		width: 260px;
	}

	.gfh-timepicker__grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.gfh-how-to-rent__steps {
		grid-template-columns: 1fr 1fr;
	}

	.gfh-info-banner__content {
		flex-direction: column;
		text-align: center;
	}

	.gfh-booking-form__summary {
		flex-direction: column;
	}

	.gfh-booking-form__photo {
		width: 100%;
		height: 200px;
	}

	.gfh-booking-form__details {
		padding: 1.5rem;
	}

	.gfh-booking-form__row {
		grid-template-columns: 1fr;
	}

	.gfh-contact__grid {
		grid-template-columns: 1fr;
	}

	.gfh-catalog__filters {
		flex-direction: column;
	}

	.gfh-catalog__filter {
		width: 100%;
	}

	.gfh-vehicle-picker__banner {
		flex-direction: column;
		gap: 1rem;
		text-align: center;
	}

	.gfh-vehicle-picker__banner-dates {
		flex-direction: column;
	}

	.gfh-vehicle-picker__grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 480px) {
	.gfh-hero__content {
		padding: 4rem 0.75rem 2.5rem;
	}

	.gfh-hero__overlay {
		background: linear-gradient(
			180deg,
			rgba(13, 13, 13, 0.8) 0%,
			rgba(26, 26, 26, 0.6) 50%,
			rgba(26, 26, 26, 0.8) 100%
		);
	}

	.gfh-booking-step1 {
		padding: 0.7rem;
		gap: 0.5rem;
	}

	.gfh-booking-step1__group-label {
		font-size: 0.65rem;
	}

	.gfh-booking-step1__row {
		gap: 0.4rem;
	}

	.gfh-booking-step1__field label {
		font-size: 0.65rem;
		margin-bottom: 0.15rem;
	}

	.gfh-picker-trigger {
		padding: 0.5rem 0.6rem;
		font-size: 0.85rem;
		gap: 0.4rem;
		border-width: 1px;
		border-radius: 4px;
	}

	.gfh-picker-trigger__icon {
		width: 14px;
		height: 14px;
	}

	.gfh-booking-step1__submit {
		padding: 0.65em;
		font-size: 0.85rem;
	}

	.gfh-timepicker__grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.gfh-how-to-rent__steps {
		grid-template-columns: 1fr;
	}

	.gfh-slider__card {
		flex: 0 0 260px;
	}

	.gfh-catalog__grid {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Trust / Book Today Section
   ========================================================================== */

.gfh-trust {
	background: var(--gfh-charcoal, #1a1a1a);
	padding: 5rem 1.5rem;
}

.gfh-trust__inner {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}

.gfh-trust__title {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: clamp(2.2rem, 5vw, 3.5rem);
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--gfh-amber, #149898);
	margin: 0 0 1rem;
}

.gfh-trust__lead {
	font-size: 1.15rem;
	color: var(--gfh-cream, #f5f0eb);
	margin: 0 0 2rem;
	line-height: 1.6;
}

.gfh-trust__list {
	list-style: none;
	padding: 0;
	margin: 0 auto 2.5rem;
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	max-width: 560px;
}

.gfh-trust__list li {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	color: var(--gfh-sand, #98b8b7);
	font-size: 1rem;
	line-height: 1.5;
}

.gfh-trust__list li svg {
	flex-shrink: 0;
	margin-top: 2px;
	stroke: var(--gfh-amber, #149898);
}

.gfh-trust__gallery {
	margin-top: 3.5rem;
	width: 100%;
}

.gfh-trust__gallery-title {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--gfh-cream, #f5f0eb);
	text-align: center;
	margin: 0 0 1.25rem;
}

.gfh-trust__gallery .gfh-gallery__header {
	display: flex;
	justify-content: flex-end;
	padding: 0 1.5rem 0.75rem;
}

.gfh-trust__gallery .gfh-gallery__arrow {
	background: transparent;
	border: 2px solid var(--gfh-cream, #f5f0eb);
	color: var(--gfh-cream, #f5f0eb);
}

.gfh-trust__gallery .gfh-gallery__arrow:hover {
	background: var(--gfh-cream, #f5f0eb);
	color: var(--gfh-charcoal, #1a1a1a);
}

/* ==========================================================================
   Customer Gallery Carousel
   ========================================================================== */

.gfh-gallery {
	padding: 4rem 1.5rem;
	background: var(--gfh-cream, #f5f0eb);
	overflow: hidden;
}

.gfh-gallery__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 1200px;
	margin: 0 auto 1.5rem;
}

.gfh-gallery__title {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--gfh-charcoal, #1a1a1a);
	margin: 0;
}

.gfh-gallery__controls {
	display: flex;
	gap: 0.5rem;
}

.gfh-gallery__arrow {
	width: 40px;
	height: 40px;
	border: 2px solid var(--gfh-charcoal, #1a1a1a);
	background: none;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, color 0.2s;
	color: var(--gfh-charcoal, #1a1a1a);
}

.gfh-gallery__arrow:hover {
	background: var(--gfh-charcoal, #1a1a1a);
	color: #fff;
}

.gfh-gallery__track {
	display: flex;
	gap: 1rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	max-width: 1200px;
	margin: 0 auto;
}

.gfh-gallery__track::-webkit-scrollbar {
	display: none;
}

.gfh-gallery__item {
	flex-shrink: 0;
	width: 300px;
	height: 220px;
	scroll-snap-align: start;
	border-radius: 6px;
	overflow: hidden;
}

.gfh-gallery__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.gfh-gallery__item:hover img {
	transform: scale(1.04);
}

@media (max-width: 768px) {
	.gfh-gallery__item {
		width: 260px;
		height: 190px;
	}
}

/* ----------  Lightbox  ---------- */

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

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

.gfh-lightbox__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.9);
}

.gfh-lightbox__close {
	position: absolute;
	top: 1rem;
	right: 1rem;
	z-index: 2;
	background: none;
	border: none;
	color: #fff;
	font-size: 2.25rem;
	line-height: 1;
	cursor: pointer;
	padding: 0.25rem 0.5rem;
	transition: opacity 0.2s;
}

.gfh-lightbox__close:hover {
	opacity: 0.7;
}

.gfh-lightbox__content {
	position: relative;
	z-index: 1;
	max-width: 90vw;
	max-height: 85vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.gfh-lightbox__img {
	max-width: 100%;
	max-height: 85vh;
	object-fit: contain;
	border-radius: 4px;
	user-select: none;
}

.gfh-lightbox__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	background: rgba(255, 255, 255, 0.12);
	border: none;
	color: #fff;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.2s;
}

.gfh-lightbox__nav:hover {
	background: rgba(255, 255, 255, 0.25);
}

.gfh-lightbox__nav--prev {
	left: 1rem;
}

.gfh-lightbox__nav--next {
	right: 1rem;
}

.gfh-lightbox__counter {
	position: absolute;
	bottom: 1.25rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.875rem;
	letter-spacing: 0.05em;
}

@media (max-width: 768px) {
	.gfh-lightbox__nav {
		width: 40px;
		height: 40px;
	}

	.gfh-lightbox__nav--prev {
		left: 0.5rem;
	}

	.gfh-lightbox__nav--next {
		right: 0.5rem;
	}

	.gfh-lightbox__close {
		top: 0.5rem;
		right: 0.5rem;
	}
}

/* ==========================================================================
   Reviews Section
   ========================================================================== */

.gfh-reviews {
	padding: 5rem 1.5rem;
	background: var(--gfh-white, #fff);
}

.gfh-reviews__title {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--gfh-charcoal, #1a1a1a);
	text-align: center;
	margin: 0 0 2.5rem;
}

.gfh-reviews__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
	max-width: 1200px;
	margin: 0 auto;
}

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

@media (max-width: 600px) {
	.gfh-reviews__grid {
		grid-template-columns: 1fr;
	}
}

.gfh-review-card {
	background: var(--gfh-cream, #f5f0eb);
	border-radius: 8px;
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.gfh-review-card__stars {
	display: flex;
	gap: 2px;
}

.gfh-review-card__star {
	font-size: 1.1rem;
	color: var(--gfh-border, #e8e0d6);
}

.gfh-review-card__star--filled {
	color: #f4a823;
}

.gfh-review-card__logo {
	margin-left: auto;
	margin-top: -2.25rem;
}

.gfh-review-card__text {
	font-size: 0.92rem;
	color: var(--gfh-charcoal, #1a1a1a);
	line-height: 1.6;
	flex: 1;
	margin: 0;
}

.gfh-review-card__footer {
	display: flex;
	align-items: baseline;
	gap: 0.75rem;
	padding-top: 0.75rem;
	border-top: 1px solid var(--gfh-border, #e8e0d6);
	margin-top: auto;
}

.gfh-review-card__author {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--gfh-charcoal, #1a1a1a);
}

.gfh-review-card__date {
	font-size: 0.78rem;
	color: var(--gfh-text-muted, #6b6b6b);
}

/* Gallery carousel JS controls */
.gfh-gallery__arrow {
	flex-shrink: 0;
}

/* ==========================================================================
   Card overlay link (makes entire card clickable)
   ========================================================================== */

.gfh-card__link {
	position: absolute;
	inset: 0;
	z-index: 1;
}

.gfh-card__cta,
.gfh-card .gfh-btn {
	position: relative;
	z-index: 2;
}

/* ==========================================================================
   Single Vehicle Detail Page
   ========================================================================== */

.gfh-vehicle-detail {
	padding: calc(var(--gfh-header-height, 72px) + 2rem) 1.5rem 4rem;
	background: var(--gfh-white, #faf8f5);
}

.gfh-vehicle-detail__inner {
	max-width: var(--gfh-max-width, 1280px);
	margin: 0 auto;
}

/* Back link */
.gfh-vehicle-detail__back {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--gfh-stone, #6b6b6b);
	text-decoration: none;
	margin-bottom: 2rem;
	transition: color 200ms ease;
}

.gfh-vehicle-detail__back:hover {
	color: var(--gfh-charcoal, #1a1a1a);
}

/* Top section: image + summary */
.gfh-vehicle-detail__top {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	align-items: start;
	margin-bottom: 3rem;
}

/* Image */
.gfh-vehicle-detail__image {
	position: relative;
	border-radius: var(--gfh-radius-lg, 12px);
	overflow: hidden;
	background: var(--gfh-dust, #e8e0d6);
	aspect-ratio: 3 / 2;
}

.gfh-vehicle-detail__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.gfh-vehicle-detail__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	color: var(--gfh-stone, #6b6b6b);
}

.gfh-vehicle-detail__badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	background: var(--gfh-charcoal, #1a1a1a);
	color: #fff;
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-size: 0.8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: 0.35rem 0.75rem;
	border-radius: 4px;
}

/* Summary */
.gfh-vehicle-detail__title {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-weight: 700;
	font-size: 2.5rem;
	line-height: 1.1;
	color: var(--gfh-charcoal, #1a1a1a);
	margin: 0 0 1rem;
}

.gfh-vehicle-detail__price {
	display: flex;
	align-items: baseline;
	gap: 0.25rem;
	margin-bottom: 1.5rem;
}

.gfh-vehicle-detail__price-amount {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-weight: 700;
	font-size: 2rem;
	color: var(--gfh-amber, #149898);
}

.gfh-vehicle-detail__price-unit {
	font-size: 1rem;
	color: var(--gfh-stone, #6b6b6b);
}

/* Description */
.gfh-vehicle-detail__description {
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 1rem;
	line-height: 1.7;
	color: var(--gfh-graphite, #3d3d3d);
	margin-bottom: 1.5rem;
	padding: 1.25rem;
	background: var(--gfh-cream, #f5f0eb);
	border-radius: var(--gfh-radius, 6px);
	border-left: 4px solid var(--gfh-amber, #149898);
}

.gfh-vehicle-detail__description p {
	margin: 0;
}

.gfh-vehicle-detail__description p + p {
	margin-top: 0.75rem;
}

/* Features */
.gfh-vehicle-detail__features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 2rem;
}

.gfh-vehicle-detail__feature {
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 0.8rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: 0.35rem 0.75rem;
	border-radius: 4px;
	background: var(--gfh-amber, #149898);
	color: #fff;
}

/* CTA */
.gfh-vehicle-detail__cta {
	display: inline-flex;
	font-size: 1.1rem;
	padding: 0.9rem 2.5rem;
}

/* Specs section */
.gfh-vehicle-detail__specs {
	border-top: 1px solid var(--gfh-dust, #e8e0d6);
	padding-top: 2.5rem;
}

.gfh-vehicle-detail__specs-title {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-weight: 700;
	font-size: 1.5rem;
	color: var(--gfh-charcoal, #1a1a1a);
	margin: 0 0 1.5rem;
}

.gfh-vehicle-detail__specs-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

.gfh-vehicle-detail__spec {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.5rem;
	padding: 1.5rem 1rem;
	background: var(--gfh-cream, #f5f0eb);
	border-radius: var(--gfh-radius-lg, 12px);
	color: var(--gfh-charcoal, #1a1a1a);
}

.gfh-vehicle-detail__spec svg {
	color: var(--gfh-amber, #149898);
}

.gfh-vehicle-detail__spec-label {
	font-family: var(--gfh-font-body, 'DM Sans', sans-serif);
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--gfh-stone, #6b6b6b);
}

.gfh-vehicle-detail__spec-value {
	font-family: var(--gfh-font-display, 'Barlow Condensed', sans-serif);
	font-weight: 700;
	font-size: 1.25rem;
	color: var(--gfh-charcoal, #1a1a1a);
}

/* Responsive: tablet */
@media (max-width: 768px) {
	.gfh-vehicle-detail__top {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.gfh-vehicle-detail__title {
		font-size: 2rem;
	}

	.gfh-vehicle-detail__specs-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Responsive: mobile */
@media (max-width: 480px) {
	.gfh-vehicle-detail {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.gfh-vehicle-detail__title {
		font-size: 1.75rem;
	}

	.gfh-vehicle-detail__price-amount {
		font-size: 1.75rem;
	}

	.gfh-vehicle-detail__specs-grid {
		grid-template-columns: 1fr 1fr;
		gap: 1rem;
	}

	.gfh-vehicle-detail__spec {
		padding: 1rem 0.75rem;
	}
}
