/* CAR Booking Form — light, high-contrast, large tap targets */
.car-booking {
	--car-primary: #1f6fce;
	--car-primary-dark: #17539b;
	--car-border: #d5dfeb;
	--car-error: #c0392b;
	background: #ffffff;
	border: 1px solid var(--car-border);
	border-radius: 14px;
	box-shadow: 0 10px 30px rgba(30, 60, 100, 0.10);
	padding: 1.5rem;
	max-width: 560px;
}

.car-booking__title {
	margin: 0 0 1rem;
	font-size: 1.4rem;
	line-height: 1.3;
}

/* Step indicator */
.car-booking__steps {
	display: flex;
	gap: 0.5rem;
	list-style: none;
	margin: 0 0 1.25rem;
	padding: 0;
	counter-reset: car-step;
}
.car-booking__steps li {
	flex: 1;
	counter-increment: car-step;
	font-size: 0.85rem;
	color: #5a6b7f;
	padding-top: 0.4rem;
	border-top: 4px solid var(--car-border);
}
.car-booking__steps li::before {
	content: counter(car-step) ". ";
	font-weight: 700;
}
.car-booking__steps li.is-active {
	color: var(--car-primary-dark);
	border-top-color: var(--car-primary);
	font-weight: 600;
}

/* Steps */
.car-booking__step {
	display: none;
	border: 0;
	margin: 0;
	padding: 0;
}
.car-booking__step.is-active { display: block; }

.car-booking__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0 1rem;
}
@media (max-width: 480px) {
	.car-booking__row { grid-template-columns: 1fr; }
}

.car-booking__field { margin: 0 0 0.9rem; }
.car-booking__field label {
	display: block;
	font-weight: 600;
	font-size: 0.95rem;
	margin-bottom: 0.3rem;
	color: #22344a;
}
.car-booking__field .req { color: var(--car-error); }

.car-booking__field input,
.car-booking__field select,
.car-booking__field textarea {
	width: 100%;
	font-size: 1rem;
	padding: 0.7rem 0.8rem;
	min-height: 48px;
	border: 1.5px solid var(--car-border);
	border-radius: 8px;
	background: #fbfcfe;
	color: #1d2b3a;
	box-sizing: border-box;
}
.car-booking__field textarea { min-height: 80px; resize: vertical; }
.car-booking__field input:focus,
.car-booking__field select:focus,
.car-booking__field textarea:focus {
	outline: 3px solid rgba(31, 111, 206, 0.35);
	border-color: var(--car-primary);
}
.car-booking__field .is-invalid,
.car-booking__field input.is-invalid,
.car-booking__field select.is-invalid,
.car-booking__field textarea.is-invalid {
	border-color: var(--car-error);
	background: #fff7f6;
}

/* Google Places Autocomplete (new PlaceAutocompleteElement web component) */
.car-booking__pac {
	width: 100%;
	min-height: 48px;
	border: 1.5px solid var(--car-border);
	border-radius: 8px;
	background: #fbfcfe;
}
/* Classic autocomplete dropdown: keep above sticky header/mobile bar */
.pac-container { z-index: 200 !important; font-family: inherit; }

/* Honeypot — visually removed */
.car-booking__hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px; height: 1px;
	overflow: hidden;
}

/* Buttons */
.car-booking__actions {
	display: flex;
	gap: 0.75rem;
	margin: 1.1rem 0 0;
}
.car-booking__next,
.car-booking__submit {
	flex: 1;
	background: var(--car-primary);
	color: #fff;
	border: 0;
	border-radius: 8px;
	font-size: 1.05rem;
	font-weight: 700;
	padding: 0.85rem 1.2rem;
	min-height: 52px;
	cursor: pointer;
	transition: background 0.15s ease;
}
.car-booking__next:hover,
.car-booking__submit:hover { background: var(--car-primary-dark); }
.car-booking__submit:disabled { opacity: 0.7; cursor: wait; }

.car-booking__back {
	background: #eef3f9;
	color: #22344a;
	border: 0;
	border-radius: 8px;
	font-size: 1rem;
	font-weight: 600;
	padding: 0.85rem 1.2rem;
	min-height: 52px;
	cursor: pointer;
}
.car-booking__back:hover { background: #e2eaf4; }

.car-booking__smallprint {
	margin: 0.75rem 0 0;
	font-size: 0.85rem;
	color: #5a6b7f;
	text-align: center;
}

.car-booking__message {
	color: var(--car-error);
	font-weight: 600;
	margin-top: 0.75rem;
	min-height: 1.2em;
}

/* Success panel */
.car-booking__success { text-align: center; padding: 1rem 0; }
.car-booking__success h3 { margin: 0 0 0.5rem; color: #1c7c43; }
.car-booking__success .car-wa-btn { margin-top: 0.75rem; }

/* WhatsApp button (shared style, also used by theme) */
.car-wa-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: #25d366;
	color: #fff !important;
	font-weight: 700;
	text-decoration: none;
	border-radius: 999px;
	padding: 0.65rem 1.2rem;
	min-height: 44px;
	box-sizing: border-box;
	transition: background 0.15s ease;
}
.car-wa-btn:hover { background: #1eb958; color: #fff; }
.car-wa-btn .car-wa-icon { flex: 0 0 auto; }
