@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700;800&family=Inter:wght@400;500;600;700&display=swap');

.ltg-booking-widget,
.ltg-booking-widget * {
	box-sizing: border-box !important;
}

.ltg-booking-widget {
	--ltg-primary: #14151a;
	--ltg-accent: #c9a14a;
	--ltg-accent-dark: #a8842f;
	--ltg-accent-soft: #f6efdf;
	--ltg-border: #e7e3d8;
	--ltg-bg: #ffffff;
	--ltg-bg-soft: #faf8f3;
	--ltg-text: #1c1d24;
	--ltg-text-muted: #7a7468;
	--ltg-success: #1f8a4c;
	--ltg-error: #c0392b;
	--ltg-radius: 16px;

	max-width: 640px !important;
	margin: 0 auto !important;
	background: var(--ltg-bg) !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: var(--ltg-radius) !important;
	padding: 36px !important;
	color: var(--ltg-text) !important;
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif !important;
	font-size: 14px !important;
	line-height: 1.55 !important;
	box-shadow: 0 18px 50px rgba(20, 20, 30, 0.08) !important;
	text-align: left !important;
}

.ltg-booking-widget *,
.ltg-booking-widget *::before,
.ltg-booking-widget *::after {
	font-family: inherit !important;
}

.ltg-booking-widget p,
.ltg-booking-widget span,
.ltg-booking-widget div {
	color: inherit;
}

.ltg-header {
	margin: 0 0 24px !important;
	text-align: center !important;
}

.ltg-header h2 {
	font-size: 24px !important;
	font-weight: 700 !important;
	margin: 0 0 6px !important;
	color: var(--ltg-primary) !important;
	background: none !important;
	border: none !important;
}

.ltg-header p {
	font-size: 14px !important;
	color: var(--ltg-text-muted) !important;
	margin: 0 !important;
}

.ltg-tabs {
	display: flex !important;
	gap: 6px !important;
	background: var(--ltg-bg-soft) !important;
	border-radius: 10px !important;
	padding: 5px !important;
	margin: 0 0 24px !important;
	border: 1px solid var(--ltg-border) !important;
}

.ltg-booking-widget button.ltg-tab {
	flex: 1 1 0 !important;
	background: transparent !important;
	border: none !important;
	color: var(--ltg-text-muted) !important;
	padding: 11px 8px !important;
	margin: 0 !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	border-radius: 7px !important;
	cursor: pointer !important;
	transition: all 0.15s ease !important;
	box-shadow: none !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	width: auto !important;
	height: auto !important;
	line-height: normal !important;
}

.ltg-booking-widget button.ltg-tab.active {
	background: #c9a14a !important;
	color: #ffffff !important;
	box-shadow: 0 1px 6px rgba(201, 161, 74, 0.4) !important;
}

.ltg-booking-widget button.ltg-tab:hover:not(.active) {
	color: var(--ltg-primary) !important;
}

.ltg-section {
	margin: 0 0 22px !important;
}

.ltg-section-label {
	display: block !important;
	font-size: 13px !important;
	font-weight: 700 !important;
	color: var(--ltg-primary) !important;
	margin: 0 0 10px !important;
}

.ltg-booking-widget label {
	display: block !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
	color: var(--ltg-text-muted) !important;
	margin: 14px 0 6px !important;
	background: none !important;
}

.ltg-booking-widget label:first-child {
	margin-top: 0 !important;
}

.ltg-booking-widget .ltg-inline-label {
	display: inline !important;
	margin: 0 8px 0 0 !important;
	text-transform: none !important;
	font-weight: 600 !important;
}

.ltg-booking-widget input[type="text"],
.ltg-booking-widget input[type="email"],
.ltg-booking-widget input[type="tel"],
.ltg-booking-widget input[type="number"],
.ltg-booking-widget input[type="datetime-local"],
.ltg-booking-widget select,
.ltg-booking-widget textarea {
	display: block !important;
	width: 100% !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
	background: var(--ltg-bg-soft) !important;
	border: 1.5px solid var(--ltg-border) !important;
	color: var(--ltg-text) !important;
	padding: 12px 14px !important;
	margin: 0 !important;
	border-radius: 9px !important;
	font-size: 14px !important;
	font-weight: 400 !important;
	outline: none !important;
	box-shadow: none !important;
	height: auto !important;
	transition: border-color 0.15s ease, background 0.15s ease !important;
	appearance: auto !important;
}

.ltg-booking-widget input:focus,
.ltg-booking-widget select:focus,
.ltg-booking-widget textarea:focus {
	border-color: var(--ltg-accent) !important;
	background: var(--ltg-bg) !important;
}

.ltg-field-pair {
	display: flex !important;
	gap: 14px !important;
}

.ltg-field-pair > div {
	flex: 1 1 0 !important;
}

.ltg-route-meta {
	display: flex !important;
	align-items: center !important;
	gap: 4px !important;
	margin: 14px 0 0 !important;
	font-size: 14px !important;
	color: var(--ltg-text) !important;
	background: var(--ltg-bg-soft) !important;
	border-radius: 9px !important;
	padding: 10px 14px !important;
}

.ltg-route-meta-divider {
	color: var(--ltg-border) !important;
	margin: 0 8px !important;
}

.ltg-zip-input {
	width: 110px !important;
	display: inline-block !important;
	padding: 6px 10px !important;
}

/* Vehicle cards */
.ltg-vehicle-grid {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
}

.ltg-vehicle-card {
	display: flex !important;
	align-items: center !important;
	gap: 14px !important;
	border: 1.5px solid var(--ltg-border) !important;
	border-radius: 12px !important;
	padding: 12px !important;
	margin: 0 !important;
	cursor: pointer !important;
	transition: border-color 0.15s ease, background 0.15s ease !important;
	background: var(--ltg-bg) !important;
}

.ltg-vehicle-card:hover {
	border-color: var(--ltg-accent) !important;
}

.ltg-vehicle-card.selected {
	border-color: var(--ltg-accent) !important;
	background: var(--ltg-accent-soft) !important;
}

.ltg-vehicle-image {
	width: 140px !important;
	height: 96px !important;
	flex-shrink: 0 !important;
	border-radius: 8px !important;
	overflow: hidden !important;
	background: var(--ltg-bg-soft) !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	margin: 0 !important;
}

.ltg-vehicle-image img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	margin: 0 !important;
	border-radius: 0 !important;
	max-width: none !important;
}

.ltg-vehicle-image-placeholder {
	font-size: 44px !important;
}

.ltg-vehicle-info {
	flex: 1 1 0 !important;
	min-width: 0 !important;
}

.ltg-vehicle-name {
	font-size: 14.5px !important;
	font-weight: 700 !important;
	color: var(--ltg-primary) !important;
	margin: 0 !important;
}

.ltg-vehicle-desc {
	font-size: 12px !important;
	color: var(--ltg-text-muted) !important;
	margin: 2px 0 0 !important;
	overflow: hidden !important;
	text-overflow: ellipsis !important;
	white-space: nowrap !important;
}

.ltg-vehicle-meta {
	display: flex !important;
	gap: 10px !important;
	margin: 5px 0 0 !important;
	font-size: 11.5px !important;
	color: var(--ltg-text-muted) !important;
}

.ltg-vehicle-meta span {
	background: var(--ltg-bg-soft) !important;
	padding: 2px 8px !important;
	border-radius: 20px !important;
	color: var(--ltg-text-muted) !important;
}

.ltg-vehicle-price {
	text-align: right !important;
	flex-shrink: 0 !important;
}

.ltg-vehicle-price-amount {
	display: block !important;
	font-size: 17px !important;
	font-weight: 700 !important;
	color: var(--ltg-primary) !important;
}

.ltg-vehicle-price-label {
	font-size: 10.5px !important;
	color: var(--ltg-text-muted) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
}

/* Price summary */
.ltg-price-display {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	background: var(--ltg-primary) !important;
	border-radius: 12px !important;
	padding: 16px 20px !important;
	margin: 22px 0 !important;
	border: none !important;
}

.ltg-price-display span {
	font-size: 13px !important;
	color: rgba(255, 255, 255, 0.75) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.05em !important;
	font-weight: 600 !important;
}

.ltg-price-display strong {
	font-size: 24px !important;
	color: var(--ltg-accent) !important;
	font-weight: 800 !important;
}

.ltg-divider {
	border-top: 1px solid var(--ltg-border) !important;
	margin: 24px 0 !important;
	height: 0 !important;
}

.ltg-booking-widget button.ltg-submit-btn {
	width: 100% !important;
	display: block !important;
	background: var(--ltg-accent) !important;
	color: #1a1a2e !important;
	border: none !important;
	padding: 16px !important;
	margin: 0 !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	letter-spacing: 0.02em !important;
	border-radius: 10px !important;
	cursor: pointer !important;
	box-shadow: none !important;
	text-transform: none !important;
	height: auto !important;
	line-height: normal !important;
	transition: filter 0.15s ease !important;
}

.ltg-booking-widget button.ltg-submit-btn:hover:not(:disabled) {
	filter: brightness(0.94) !important;
}

.ltg-booking-widget button.ltg-submit-btn:disabled {
	background: var(--ltg-border) !important;
	color: var(--ltg-text-muted) !important;
	cursor: not-allowed !important;
}

.ltg-form-message {
	margin: 14px 0 0 !important;
	font-size: 13px !important;
	min-height: 18px !important;
	font-weight: 600 !important;
	text-align: center !important;
	color: var(--ltg-text) !important;
}

.ltg-form-message.error {
	color: var(--ltg-error) !important;
}

.ltg-form-message.success {
	color: var(--ltg-success) !important;
}

#ltg-payment-element {
	background: var(--ltg-bg-soft) !important;
	border-radius: 10px !important;
	padding: 14px !important;
}

@media (max-width: 480px) {
	.ltg-booking-widget {
		padding: 20px !important;
		border-radius: 0 !important;
		border-left: none !important;
		border-right: none !important;
	}
	.ltg-field-pair {
		flex-direction: column !important;
		gap: 0 !important;
	}
	.ltg-vehicle-card {
		flex-wrap: wrap !important;
	}
	.ltg-vehicle-price {
		width: 100% !important;
		text-align: left !important;
		margin-top: 8px !important;
		padding-left: 154px !important;
	}
}

/* ===== v1.2.0 additions: extras, gratuity, price breakdown, route status ===== */

.ltg-booking-widget .ltg-route-status {
	margin: 10px 0 0 !important;
	font-size: 13px !important;
	color: var(--ltg-error) !important;
	min-height: 18px !important;
}

.ltg-booking-widget .ltg-extras-grid {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	gap: 10px !important;
	align-items: stretch !important;
}

@media (max-width: 600px) {
	.ltg-booking-widget .ltg-extras-grid {
		grid-template-columns: 1fr !important;
	}
}

.ltg-booking-widget .ltg-extra-option {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	width: 100% !important;
	min-height: 56px !important;
	padding: 12px 14px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 10px !important;
	cursor: pointer !important;
	transition: border-color 0.15s ease, background 0.15s ease !important;
}

.ltg-booking-widget .ltg-extra-option:hover {
	border-color: var(--ltg-accent) !important;
}

.ltg-booking-widget .ltg-extra-checkbox {
	width: 16px !important;
	height: 16px !important;
	accent-color: var(--ltg-accent) !important;
	margin: 0 !important;
}

.ltg-booking-widget .ltg-extra-name {
	flex: 1 1 auto !important;
	min-width: 0 !important;
	font-weight: 600 !important;
	color: var(--ltg-primary) !important;
}

.ltg-booking-widget .ltg-extra-price {
	font-weight: 600 !important;
	color: var(--ltg-accent) !important;
	white-space: nowrap !important;
}

/* ----- Date & time ----- */
.ltg-booking-widget .ltg-datetime-row {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 12px !important;
}

.ltg-booking-widget .ltg-datetime-field {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	padding: 10px 12px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 10px !important;
	background: var(--ltg-bg) !important;
	transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
}

.ltg-booking-widget .ltg-datetime-field:focus-within {
	border-color: var(--ltg-accent) !important;
	box-shadow: 0 0 0 3px rgba(201, 161, 74, 0.15) !important;
}

.ltg-booking-widget .ltg-datetime-icon {
	font-size: 16px !important;
	line-height: 1 !important;
}

.ltg-booking-widget .ltg-datetime-field input {
	border: none !important;
	outline: none !important;
	background: transparent !important;
	width: 100% !important;
	padding: 0 !important;
	font-size: 14px !important;
	color: var(--ltg-text) !important;
}

@media (max-width: 480px) {
	.ltg-booking-widget .ltg-datetime-row { grid-template-columns: 1fr !important; }
}

/* ----- Gratuity panel ----- */
.ltg-booking-widget .ltg-gratuity {
	padding: 16px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 12px !important;
	background: var(--ltg-bg-soft) !important;
}

.ltg-booking-widget .ltg-tip-switch {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	cursor: pointer !important;
	margin: 0 !important;
}

.ltg-booking-widget .ltg-tip-switch-label {
	font-weight: 700 !important;
	color: var(--ltg-primary) !important;
}

/* iOS-style switch */
.ltg-booking-widget .ltg-switch {
	position: relative !important;
	display: inline-block !important;
	width: 46px !important;
	height: 26px !important;
	flex: 0 0 auto !important;
}

.ltg-booking-widget .ltg-switch input {
	position: absolute !important;
	opacity: 0 !important;
	width: 100% !important;
	height: 100% !important;
	margin: 0 !important;
	cursor: pointer !important;
}

.ltg-booking-widget .ltg-switch-track {
	position: absolute !important;
	inset: 0 !important;
	background: #cfd2db !important;
	border-radius: 999px !important;
	transition: background 0.2s ease !important;
}

.ltg-booking-widget .ltg-switch-thumb {
	position: absolute !important;
	top: 3px !important;
	left: 3px !important;
	width: 20px !important;
	height: 20px !important;
	background: #fff !important;
	border-radius: 50% !important;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25) !important;
	transition: transform 0.2s ease !important;
}

.ltg-booking-widget .ltg-switch input:checked + .ltg-switch-track {
	background: var(--ltg-accent) !important;
}

.ltg-booking-widget .ltg-switch input:checked + .ltg-switch-track .ltg-switch-thumb {
	transform: translateX(20px) !important;
}

.ltg-booking-widget .ltg-tip-panel {
	margin-top: 14px !important;
}

.ltg-booking-widget .ltg-tip-presets {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 8px !important;
	margin-bottom: 12px !important;
}

.ltg-booking-widget .ltg-tip-preset {
	flex: 1 1 0 !important;
	min-width: 64px !important;
	padding: 10px 0 !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 10px !important;
	background: var(--ltg-bg) !important;
	color: var(--ltg-primary) !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: all 0.15s ease !important;
}

.ltg-booking-widget .ltg-tip-preset:hover {
	border-color: var(--ltg-accent) !important;
}

.ltg-booking-widget .ltg-tip-preset.active {
	background: var(--ltg-accent) !important;
	border-color: var(--ltg-accent) !important;
	color: #fff !important;
}

.ltg-booking-widget .ltg-tip-custom {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
}

.ltg-booking-widget .ltg-tip-custom label {
	font-size: 13px !important;
	color: var(--ltg-text-muted) !important;
	margin: 0 !important;
}

.ltg-booking-widget .ltg-tip-input-wrap {
	position: relative !important;
	width: 110px !important;
}

.ltg-booking-widget .ltg-tip-input {
	width: 100% !important;
	padding-right: 26px !important;
}

.ltg-booking-widget .ltg-tip-pct-sign {
	position: absolute !important;
	right: 12px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	color: var(--ltg-text-muted) !important;
	font-weight: 600 !important;
	pointer-events: none !important;
}

.ltg-booking-widget .ltg-price-breakdown {
	margin: 18px 0 6px !important;
	padding: 14px 16px !important;
	background: var(--ltg-bg-soft) !important;
	border-radius: 10px !important;
}

.ltg-booking-widget .ltg-price-line {
	display: flex !important;
	justify-content: space-between !important;
	font-size: 14px !important;
	color: var(--ltg-text-muted) !important;
	padding: 3px 0 !important;
}

.ltg-booking-widget .ltg-price-line span:last-child {
	font-weight: 600 !important;
	color: var(--ltg-text) !important;
}

/* ===== v1.3.0 additions: route map, flight info tooltip, tip toggle ===== */

/* Google Places autocomplete dropdown — keep it above themed page layers. */
.pac-container {
	z-index: 100000 !important;
}

.ltg-booking-widget .ltg-map-wrap {
	margin-top: 4px !important;
}

.ltg-booking-widget .ltg-map {
	width: 100% !important;
	height: 240px !important;
	border-radius: 12px !important;
	overflow: hidden !important;
	border: 1px solid var(--ltg-border) !important;
}

.ltg-booking-widget .ltg-route-meta {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	margin-top: 10px !important;
	font-size: 13px !important;
	color: var(--ltg-text-muted) !important;
}

.ltg-booking-widget .ltg-rate-note {
	color: var(--ltg-accent) !important;
	font-weight: 600 !important;
}

/* Flight-monitoring info tooltip */
.ltg-booking-widget .ltg-info {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 16px !important;
	height: 16px !important;
	margin-left: 6px !important;
	border-radius: 50% !important;
	background: var(--ltg-accent) !important;
	color: #fff !important;
	font-size: 11px !important;
	font-style: italic !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	cursor: help !important;
	position: relative !important;
	vertical-align: middle !important;
}

.ltg-booking-widget .ltg-info-bubble {
	visibility: hidden !important;
	opacity: 0 !important;
	position: absolute !important;
	bottom: 140% !important;
	left: 50% !important;
	transform: translateX(-50%) !important;
	width: 240px !important;
	max-width: 70vw !important;
	padding: 10px 12px !important;
	background: var(--ltg-primary) !important;
	color: #fff !important;
	font-size: 12px !important;
	font-style: normal !important;
	font-weight: 400 !important;
	line-height: 1.45 !important;
	border-radius: 8px !important;
	box-shadow: 0 6px 20px rgba(20, 20, 40, 0.25) !important;
	z-index: 50 !important;
	transition: opacity 0.15s ease !important;
	pointer-events: none !important;
}

.ltg-booking-widget .ltg-info:hover .ltg-info-bubble,
.ltg-booking-widget .ltg-info:focus .ltg-info-bubble {
	visibility: visible !important;
	opacity: 1 !important;
}

/* ===== v1.5.0 additions: wider on large screens, round trip, service area ===== */

/* Wider, easier-to-read form on large screens (kept narrow on small/mobile). */
@media (min-width: 1024px) {
	.ltg-booking-widget {
		max-width: 820px !important;
		padding: 40px !important;
	}
}
@media (min-width: 1440px) {
	.ltg-booking-widget {
		max-width: 900px !important;
	}
}

/* Belt-and-suspenders for equal-size extras regardless of theme CSS. */
.ltg-booking-widget .ltg-extras-grid {
	grid-auto-rows: 1fr !important;
}
.ltg-booking-widget .ltg-extra-option {
	box-sizing: border-box !important;
	justify-content: space-between !important;
}
.ltg-booking-widget .ltg-extra-price {
	margin-left: auto !important;
}

/* Trip type (one way / round trip) */
.ltg-booking-widget .ltg-trip-type {
	display: flex !important;
	gap: 8px !important;
	margin-top: 12px !important;
}
.ltg-booking-widget .ltg-trip-btn {
	flex: 1 1 0 !important;
	padding: 10px 0 !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 10px !important;
	background: var(--ltg-bg) !important;
	color: var(--ltg-primary) !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	cursor: pointer !important;
	transition: all 0.15s ease !important;
}
.ltg-booking-widget .ltg-trip-btn:hover {
	border-color: var(--ltg-accent) !important;
}
.ltg-booking-widget .ltg-trip-btn.active {
	background: var(--ltg-accent) !important;
	border-color: var(--ltg-accent) !important;
	color: #fff !important;
}

/* Out-of-service-area message */
.ltg-booking-widget .ltg-area-status {
	margin: 10px 0 0 !important;
	color: var(--ltg-error) !important;
	font-size: 13px !important;
	font-weight: 600 !important;
}
.ltg-booking-widget .ltg-area-status:empty {
	display: none !important;
}

/* ===== v1.6.0: Start New Trip button ===== */
.ltg-booking-widget .ltg-header { position: relative !important; }
.ltg-booking-widget .ltg-flush-btn {
	margin-top: 12px !important;
	padding: 8px 16px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 999px !important;
	background: var(--ltg-bg) !important;
	color: var(--ltg-primary) !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	cursor: pointer !important;
	transition: all 0.15s ease !important;
}
.ltg-booking-widget .ltg-flush-btn:hover {
	border-color: var(--ltg-accent) !important;
	color: var(--ltg-accent) !important;
}

/* ===== v1.8.0: return trip, vehicle category ===== */

.ltg-booking-widget .ltg-return-trip {
	padding: 16px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 12px !important;
	background: var(--ltg-bg-soft) !important;
}
.ltg-booking-widget .ltg-return-icon {
	color: var(--ltg-accent) !important;
	margin-right: 2px !important;
}
.ltg-booking-widget .ltg-save-badge {
	display: inline-block !important;
	margin-left: 8px !important;
	padding: 2px 8px !important;
	border-radius: 999px !important;
	background: #e6f4ea !important;
	color: #1e7e34 !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	vertical-align: middle !important;
}
.ltg-booking-widget .ltg-return-sub {
	display: block !important;
	margin-top: 2px !important;
	font-size: 12px !important;
	font-weight: 400 !important;
	color: var(--ltg-text-muted) !important;
}
.ltg-booking-widget .ltg-return-fields {
	margin-top: 16px !important;
	padding-top: 16px !important;
	border-top: 1px solid var(--ltg-border) !important;
}
.ltg-booking-widget .ltg-return-label {
	display: block !important;
	margin-bottom: 6px !important;
	font-weight: 600 !important;
	color: var(--ltg-primary) !important;
}
.ltg-booking-widget .ltg-return-note {
	margin: 12px 0 0 !important;
	font-size: 13px !important;
	color: var(--ltg-text-muted) !important;
}

/* Vehicle category badge on the card */
.ltg-booking-widget .ltg-vehicle-cat {
	display: inline-block !important;
	margin-left: 8px !important;
	padding: 1px 8px !important;
	border-radius: 999px !important;
	background: var(--ltg-bg-soft) !important;
	border: 1px solid var(--ltg-border) !important;
	color: var(--ltg-text-muted) !important;
	font-size: 11px !important;
	font-weight: 600 !important;
	vertical-align: middle !important;
}

/* ===== v1.9.0: reliably hide breakdown lines (beats display:flex !important) ===== */
.ltg-booking-widget .ltg-price-line.ltg-line-hidden { display: none !important; }

/* Add-on description + quantity stepper */
.ltg-booking-widget .ltg-extra-info { display: flex; flex-direction: column; min-width: 0; flex: 1 1 auto; }
.ltg-booking-widget .ltg-extra-desc {
	font-size: 11px !important;
	font-weight: 400 !important;
	color: var(--ltg-text-muted) !important;
	line-height: 1.3 !important;
	margin-top: 2px !important;
}
.ltg-booking-widget .ltg-extra-qty {
	display: flex !important;
	align-items: center !important;
	gap: 6px !important;
	margin-left: 8px !important;
}
.ltg-booking-widget .ltg-qty-btn {
	width: 24px !important;
	height: 24px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 6px !important;
	background: var(--ltg-bg) !important;
	color: var(--ltg-primary) !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	cursor: pointer !important;
	padding: 0 !important;
}
.ltg-booking-widget .ltg-qty-btn:hover { border-color: var(--ltg-accent) !important; }
.ltg-booking-widget .ltg-qty-input {
	width: 34px !important;
	text-align: center !important;
	padding: 2px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 6px !important;
	font-weight: 600 !important;
}

/* ===== v2.0.0: per-add-on breakdown lines + return-trip note ===== */
.ltg-booking-widget .ltg-price-line-addon span:first-child {
	color: var(--ltg-text-muted) !important;
}
.ltg-booking-widget .ltg-roundtrip-note {
	display: flex !important;
	align-items: center !important;
	justify-content: flex-end !important;
	text-align: right !important;
	gap: 6px !important;
	margin: 8px 0 0 !important;
	padding: 8px 12px !important;
	background: var(--ltg-bg-soft) !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 8px !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	color: var(--ltg-accent) !important;
}
.ltg-booking-widget .ltg-roundtrip-note.ltg-line-hidden { display: none !important; }

/* ===== v2.1.0: two-step payment UI + required marker ===== */
.ltg-booking-widget .ltg-req { color: var(--ltg-error) !important; }

.ltg-booking-widget .ltg-payment-section {
	margin-top: 16px !important;
	padding: 18px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 12px !important;
	background: var(--ltg-bg-soft) !important;
}
.ltg-booking-widget .ltg-payment-heading {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	margin-bottom: 14px !important;
	font-weight: 600 !important;
	color: var(--ltg-primary) !important;
}
.ltg-booking-widget .ltg-payment-heading strong { color: var(--ltg-accent) !important; }
.ltg-booking-widget #ltg-payment-element { margin-bottom: 14px !important; }
.ltg-booking-widget .ltg-pay-back {
	display: block !important;
	width: 100% !important;
	margin-top: 10px !important;
	padding: 8px !important;
	background: transparent !important;
	border: none !important;
	color: var(--ltg-text-muted) !important;
	font-size: 13px !important;
	cursor: pointer !important;
}
.ltg-booking-widget .ltg-pay-back:hover { color: var(--ltg-primary) !important; }

/* ===== v2.3.0: custom time selects + labeled split card fields ===== */
.ltg-booking-widget .ltg-time-field {
	gap: 6px !important;
	flex-wrap: nowrap !important;
}
.ltg-booking-widget .ltg-time-sel {
	flex: 1 1 auto !important;
	min-width: 0 !important;
	padding: 10px 6px !important;
	border: none !important;
	background: transparent !important;
	font-size: 15px !important;
	color: var(--ltg-primary) !important;
	cursor: pointer !important;
	-webkit-appearance: menulist !important;
	appearance: menulist !important;
}
.ltg-booking-widget .ltg-time-colon { font-weight: 700 !important; color: var(--ltg-text-muted) !important; }

/* Split card fields */
.ltg-booking-widget .ltg-card-field { margin-bottom: 12px !important; }
.ltg-booking-widget .ltg-card-field > label {
	display: block !important;
	margin-bottom: 6px !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	color: var(--ltg-primary) !important;
}
.ltg-booking-widget .ltg-stripe-input {
	padding: 12px 14px !important;
	border: 1px solid var(--ltg-border) !important;
	border-radius: 10px !important;
	background: #ffffff !important;
}
.ltg-booking-widget .ltg-card-row {
	display: flex !important;
	gap: 12px !important;
}
.ltg-booking-widget .ltg-card-row .ltg-card-field {
	flex: 1 1 0 !important;
	min-width: 0 !important;
}

/* ===== v2.4.1: consistent date/time field height (pickup + return match) ===== */
.ltg-booking-widget .ltg-datetime-field {
	min-height: 46px !important;
	box-sizing: border-box !important;
}
.ltg-booking-widget .ltg-time-sel {
	padding-top: 4px !important;
	padding-bottom: 4px !important;
}

/* ===== v2.5.0: highlight the Pickup Date & Time section ===== */
.ltg-booking-widget .ltg-section-highlight {
	background: linear-gradient(0deg, rgba(201, 161, 74, 0.07), rgba(201, 161, 74, 0.07)), var(--ltg-bg) !important;
	border: 1px solid rgba(201, 161, 74, 0.35) !important;
	border-left: 4px solid var(--ltg-accent) !important;
	border-radius: 12px !important;
	padding: 16px !important;
}

/* ===== v2.7.0: vehicle perks / amenities pills ===== */
.ltg-booking-widget .ltg-vehicle-perks {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 6px !important;
	margin-top: 8px !important;
}
.ltg-booking-widget .ltg-perk {
	display: inline-flex !important;
	align-items: center !important;
	gap: 3px !important;
	padding: 2px 9px !important;
	border-radius: 999px !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	line-height: 1.6 !important;
	white-space: nowrap !important;
}
.ltg-booking-widget .ltg-perk-0 { background: #e3f6e8 !important; color: #1e7e34 !important; }
.ltg-booking-widget .ltg-perk-1 { background: #e4eefc !important; color: #1c5fb0 !important; }
.ltg-booking-widget .ltg-perk-2 { background: #fde9f1 !important; color: #b03a6b !important; }
.ltg-booking-widget .ltg-perk-3 { background: #fff1de !important; color: #b3631a !important; }
.ltg-booking-widget .ltg-perk-4 { background: #ece6fb !important; color: #5b3bb0 !important; }
.ltg-booking-widget .ltg-perk-5 { background: #e0f6f5 !important; color: #0e7c7b !important; }

/* ===== v2.9.0: elegant luxury restyle (serif headings, refined buttons) ===== */

/* Serif display headings */
.ltg-booking-widget .ltg-header h2 {
	font-family: 'Playfair Display', Georgia, 'Times New Roman', serif !important;
	font-size: 30px !important;
	font-weight: 700 !important;
	letter-spacing: 0.01em !important;
	margin-bottom: 8px !important;
}
.ltg-booking-widget .ltg-header p {
	font-size: 13px !important;
	letter-spacing: 0.01em !important;
}
.ltg-booking-widget .ltg-header::after {
	content: "" !important;
	display: block !important;
	width: 52px !important;
	height: 3px !important;
	margin: 14px auto 0 !important;
	background: var(--ltg-accent) !important;
	border-radius: 3px !important;
}

/* Uppercase, letter-spaced section labels — a luxury cue */
.ltg-booking-widget .ltg-section-label {
	font-size: 11px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.16em !important;
	color: var(--ltg-text-muted) !important;
	margin-bottom: 12px !important;
}

/* Tabs: refined, uppercase */
.ltg-booking-widget .ltg-tabs {
	background: var(--ltg-bg-soft) !important;
	border-radius: 12px !important;
}
.ltg-booking-widget button.ltg-tab {
	text-transform: uppercase !important;
	letter-spacing: 0.1em !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	padding: 13px 8px !important;
}
.ltg-booking-widget button.ltg-tab.active {
	background: var(--ltg-accent) !important;
	color: #fff !important;
	box-shadow: 0 4px 14px rgba(201,161,74,0.35) !important;
}

/* Primary buttons: elegant gold, uppercase, spaced */
.ltg-booking-widget button.ltg-submit-btn {
	background: var(--ltg-accent) !important;
	color: #14151a !important;
	text-transform: uppercase !important;
	letter-spacing: 0.12em !important;
	font-weight: 700 !important;
	font-size: 13px !important;
	padding: 17px !important;
	border-radius: 12px !important;
	box-shadow: 0 8px 22px rgba(201,161,74,0.32) !important;
	transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.1s ease !important;
}
.ltg-booking-widget button.ltg-submit-btn:hover:not(:disabled) {
	background: var(--ltg-accent-dark) !important;
	filter: none !important;
	box-shadow: 0 10px 26px rgba(201,161,74,0.45) !important;
}
.ltg-booking-widget button.ltg-submit-btn:disabled {
	background: #efece4 !important;
	color: #b3ad9f !important;
	box-shadow: none !important;
}

/* Trip-type + flush + tip presets: refined */
.ltg-booking-widget .ltg-trip-btn,
.ltg-booking-widget .ltg-flush-btn {
	text-transform: uppercase !important;
	letter-spacing: 0.08em !important;
	font-size: 12px !important;
}
.ltg-booking-widget .ltg-trip-btn.active {
	background: var(--ltg-primary) !important;
	border-color: var(--ltg-primary) !important;
}

/* Total display: serif number for a premium feel */
.ltg-booking-widget .ltg-price-display strong {
	font-family: 'Playfair Display', Georgia, serif !important;
}
.ltg-booking-widget .ltg-price-display span {
	text-transform: uppercase !important;
	letter-spacing: 0.12em !important;
	font-size: 12px !important;
	color: var(--ltg-text-muted) !important;
}

/* Vehicle name a touch more refined */
.ltg-booking-widget .ltg-vehicle-name {
	font-weight: 700 !important;
	letter-spacing: 0.01em !important;
}

/* ===== v2.9.1: distinct add-ons section + reliable single column on phones ===== */
.ltg-booking-widget .ltg-section-addons {
	background: #f4f6f8 !important;
	border: 1px solid #e3e7ec !important;
	border-radius: 14px !important;
	padding: 18px !important;
}
.ltg-booking-widget .ltg-section-addons .ltg-extra-option {
	background: #ffffff !important;
}
@media (max-width: 600px) {
	.ltg-booking-widget .ltg-extras-grid {
		grid-template-columns: 1fr !important;
		gap: 12px !important;
	}
	/* Give each add-on room so the name, price and stepper never overlap. */
	.ltg-booking-widget .ltg-extra-option {
		flex-wrap: wrap !important;
		row-gap: 6px !important;
	}
	.ltg-booking-widget .ltg-extra-price {
		margin-left: auto !important;
	}
}

/* ===== v3.1.1: clearer, gold Total in the long form ===== */
.ltg-booking-widget .ltg-price-display {
	padding: 18px 22px !important;
}
.ltg-booking-widget .ltg-price-display span {
	color: var(--ltg-accent) !important;
	font-size: 16px !important;
	font-weight: 800 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	opacity: 1 !important;
}
.ltg-booking-widget #ltg-price-total {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif !important;
	font-size: 32px !important;
	font-weight: 800 !important;
	color: var(--ltg-accent) !important;
	letter-spacing: 0.01em !important;
}

/* ===== v3.9.0: button loading spinner ===== */
.ltg-booking-widget .ltg-spinner {
	display: inline-block !important;
	width: 18px !important;
	height: 18px !important;
	margin-right: 10px !important;
	vertical-align: -4px !important;
	border: 3px solid rgba(20,20,30,0.25) !important;
	border-top-color: #14151a !important;
	border-radius: 50% !important;
	animation: ltg-spin 0.6s linear infinite !important;
	box-sizing: border-box !important;
}
@keyframes ltg-spin { to { transform: rotate(360deg); } }
.ltg-booking-widget .ltg-pay-loading {
	display: flex !important;
	align-items: center !important;
	gap: 10px !important;
	padding: 16px 4px !important;
	color: var(--ltg-text-muted) !important;
	font-size: 14px !important;
}
.ltg-booking-widget .ltg-pay-loading .ltg-spinner {
	color: var(--ltg-accent) !important;
	margin-right: 0 !important;
}

/* ===== v3.9.2: force-hide the submit button (beats display:block !important) ===== */
.ltg-booking-widget button.ltg-submit-btn.ltg-hidden { display: none !important; }
