@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700;800&display=swap');
/**
 * Rentacar Booking - Public Booking Form Stylesheet
 *
 * 7-step responsive booking flow.
 * Theme: Okinawa Tropical Orange
 *
 * All selectors scoped to #rc-booking-app for high specificity
 * to prevent WordPress theme CSS from overriding plugin styles.
 *
 * IMPORTANT: @import MUST be the very first rule in CSS (before any comments
 * or other rules) per CSS specification. Browsers silently ignore @import
 * that appears after any other rule, which can break font loading.
 *
 * @package RentacarBooking
 * @since   1.0.1
 */

/* ─────────────────────────────────────────────
 * Variables — Okinawa Tropical Orange Theme
 * ───────────────────────────────────────────── */
:root {
	--rcb-primary: #F7931E;
	--rcb-primary-hover: #E07A00;
	--rcb-primary-light: #FFF3E4;
	--rcb-success: #16a34a;
	--rcb-success-light: #dcfce7;
	--rcb-warning: #d97706;
	--rcb-warning-light: #fef3c7;
	--rcb-danger: #dc2626;
	--rcb-danger-light: #fee2e2;
	--rcb-gray-50: #FFF8EF;
	--rcb-gray-100: #FFF3E4;
	--rcb-gray-200: #EFE7DA;
	--rcb-gray-300: #d1d5db;
	--rcb-gray-500: #6b7280;
	--rcb-gray-700: #374151;
	--rcb-gray-900: #222222;
	--rcb-white: #ffffff;
	--rcb-radius: 18px;
	--rcb-radius-sm: 12px;
	--rcb-shadow: 0 4px 16px rgba(0,0,0,.06), 0 1px 4px rgba(0,0,0,.04);
	--rcb-shadow-md: 0 8px 30px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.04);
	--rcb-font: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Hiragino Sans", sans-serif;
	--rcb-transition: .25s ease;
}

/* ─────────────────────────────────────────────
 * Base — scoped to #rc-booking-app
 * ───────────────────────────────────────────── */
#rc-booking-app.rc-booking {
	position: relative;
	max-width: 880px;
	margin: 0 auto;
	padding: 32px 24px;
	font-family: var(--rcb-font) !important;
	font-size: 15px !important;
	line-height: 1.7 !important;
	color: var(--rcb-gray-900) !important;
	background: var(--rcb-gray-50) !important;
	border-radius: var(--rcb-radius);
	-webkit-font-smoothing: antialiased;
}
#rc-booking-app *, #rc-booking-app *::before, #rc-booking-app *::after {
	box-sizing: border-box;
}
/* Utility: force-hide elements (beats any theme CSS) */
#rc-booking-app .rc-hidden {
	display: none !important;
}
/* Reset theme overrides on common elements inside our app */
#rc-booking-app h2,
#rc-booking-app h3,
#rc-booking-app h4,
#rc-booking-app p,
#rc-booking-app ul,
#rc-booking-app ol,
#rc-booking-app li,
#rc-booking-app dl,
#rc-booking-app dt,
#rc-booking-app dd,
#rc-booking-app nav,
#rc-booking-app section,
#rc-booking-app label,
#rc-booking-app span,
#rc-booking-app div {
	margin: 0;
	padding: 0;
	border: none;
	background: none;
	font-family: inherit;
	color: inherit;
	letter-spacing: normal;
	text-transform: none;
	text-decoration: none;
}
#rc-booking-app a {
	color: var(--rcb-primary);
	text-decoration: none;
}
#rc-booking-app button {
	font-family: var(--rcb-font) !important;
	cursor: pointer;
	border: none;
	outline: none;
	background: none;
}
#rc-booking-app input,
#rc-booking-app select,
#rc-booking-app textarea {
	font-family: var(--rcb-font) !important;
}

/* ─────────────────────────────────────────────
 * Notice
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-booking__notice {
	background: var(--rcb-warning-light) !important;
	border: 1px solid var(--rcb-warning) !important;
	border-radius: var(--rcb-radius-sm) !important;
	padding: 12px 18px !important;
	margin-bottom: 20px !important;
	font-size: 14px !important;
	color: #92400e !important;
	box-shadow: var(--rcb-shadow);
}

/* ─────────────────────────────────────────────
 * Error
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-booking__error {
	background: var(--rcb-danger-light) !important;
	border: 1px solid var(--rcb-danger) !important;
	border-radius: var(--rcb-radius-sm) !important;
	padding: 10px 14px !important;
	margin-bottom: 16px !important;
	font-size: 14px !important;
	color: #991b1b !important;
}

/* ─────────────────────────────────────────────
 * Progress Bar — CRITICAL: must beat theme ol/li
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-progress {
	margin-bottom: 28px !important;
	padding: 0 !important;
	background: none !important;
	border: none !important;
}
#rc-booking-app .rc-progress__list {
	display: flex !important;
	list-style: none !important;
	list-style-type: none !important;
	margin: 0 !important;
	padding: 0 !important;
	counter-reset: none !important;
	position: relative;
}
#rc-booking-app .rc-progress__list > li.rc-progress__item {
	flex: 1 !important;
	text-align: center !important;
	position: relative;
	list-style: none !important;
	list-style-type: none !important;
	margin: 0 !important;
	padding: 0 !important;
	float: none !important;
	display: block !important;
}
/* Connector line between steps */
#rc-booking-app .rc-progress__list > li.rc-progress__item::before {
	content: '' !important;
	position: absolute !important;
	top: 16px !important;
	left: -50% !important;
	right: 50% !important;
	height: 2px !important;
	background: var(--rcb-gray-200) !important;
	z-index: 0 !important;
	border: none !important;
	border-radius: 0 !important;
	width: auto !important;
}
#rc-booking-app .rc-progress__list > li.rc-progress__item:first-child::before {
	display: none !important;
}
#rc-booking-app .rc-progress__list > li.rc-progress__item--active::before,
#rc-booking-app .rc-progress__list > li.rc-progress__item--done::before {
	background: var(--rcb-primary) !important;
}

/* Step number circle */
#rc-booking-app .rc-progress__num {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 36px !important;
	height: 36px !important;
	border-radius: 50% !important;
	background: var(--rcb-white) !important;
	color: var(--rcb-gray-500) !important;
	font-weight: 700 !important;
	font-size: 14px !important;
	position: relative !important;
	z-index: 1 !important;
	border: 2.5px solid var(--rcb-gray-200) !important;
	transition: all var(--rcb-transition);
	line-height: 1 !important;
	margin: 0 auto !important;
	padding: 0 !important;
}
#rc-booking-app .rc-progress__item--active .rc-progress__num {
	background: var(--rcb-primary) !important;
	color: var(--rcb-white) !important;
	border-color: var(--rcb-primary) !important;
	box-shadow: 0 3px 12px rgba(247,147,30,.3);
}
#rc-booking-app .rc-progress__item--done .rc-progress__num {
	background: var(--rcb-success) !important;
	color: var(--rcb-white) !important;
	border-color: var(--rcb-success) !important;
}

/* Step label text */
#rc-booking-app .rc-progress__label {
	display: block !important;
	font-size: 11px !important;
	color: var(--rcb-gray-500) !important;
	margin-top: 4px !important;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	font-weight: 500 !important;
	line-height: 1.4 !important;
	padding: 0 !important;
}
#rc-booking-app .rc-progress__item--active .rc-progress__label {
	color: var(--rcb-primary) !important;
	font-weight: 700 !important;
}
#rc-booking-app .rc-progress__item--done .rc-progress__label {
	color: var(--rcb-success) !important;
}

/* ─────────────────────────────────────────────
 * Step Container
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-step {
	animation: rcFadeIn .3s ease;
}
@keyframes rcFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}
#rc-booking-app .rc-step__title {
	font-size: 22px !important;
	font-weight: 800 !important;
	margin: 0 0 20px 0 !important;
	padding: 0 0 14px 0 !important;
	border: none !important;
	border-bottom: 3px solid var(--rcb-primary) !important;
	color: var(--rcb-gray-900) !important;
	line-height: 1.4 !important;
	background: none !important;
	letter-spacing: normal !important;
	text-transform: none !important;
}
#rc-booking-app .rc-step__desc {
	color: var(--rcb-gray-500) !important;
	margin: 0 0 16px 0 !important;
	font-size: 14px !important;
}

/* ─────────────────────────────────────────────
 * Vehicle Grid (Step 1)
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-vehicle-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
	gap: 16px !important;
}
#rc-booking-app .rc-vehicle-card {
	background: var(--rcb-white) !important;
	border: 1.5px solid var(--rcb-gray-200) !important;
	border-radius: var(--rcb-radius) !important;
	padding: 0 !important;
	cursor: pointer;
	transition: all var(--rcb-transition);
	display: flex !important;
	flex-direction: column !important;
	overflow: hidden !important;
	box-shadow: var(--rcb-shadow) !important;
}
#rc-booking-app .rc-vehicle-card:hover {
	border-color: #FFB347 !important;
	box-shadow: var(--rcb-shadow-md) !important;
	transform: translateY(-3px);
}
#rc-booking-app .rc-vehicle-card--selected {
	border-color: var(--rcb-primary) !important;
	background: var(--rcb-primary-light) !important;
	box-shadow: 0 0 0 3px rgba(247,147,30,.15), var(--rcb-shadow) !important;
}
#rc-booking-app .rc-vehicle-card__img {
	width: 100% !important;
	height: 160px !important;
	object-fit: cover !important;
	border-radius: 0 !important;
	background: linear-gradient(135deg, #f5f0e8 0%, #efe7da 100%) !important;
	margin: 0 !important;
	display: block !important;
}
#rc-booking-app .rc-vehicle-card__body {
	padding: 16px 18px !important;
}
#rc-booking-app .rc-vehicle-card__name {
	font-size: 16px !important;
	font-weight: 600 !important;
	margin-bottom: 4px !important;
	color: var(--rcb-gray-900) !important;
}
#rc-booking-app .rc-vehicle-card__meta {
	font-size: 13px !important;
	color: var(--rcb-gray-500) !important;
	margin-bottom: 8px !important;
}
#rc-booking-app .rc-vehicle-card__price {
	font-size: 24px !important;
	font-weight: 800 !important;
	color: var(--rcb-primary) !important;
	margin-top: auto;
}

/* ─────────────────────────────────────────────
 * Date Selection (Step 2)
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-date-section {
	display: grid !important;
	grid-template-columns: 1fr 1fr !important;
	gap: 16px !important;
	margin-bottom: 16px !important;
}
#rc-booking-app .rc-date-field label {
	display: block !important;
	font-weight: 600 !important;
	margin-bottom: 6px !important;
	font-size: 14px !important;
	color: var(--rcb-gray-900) !important;
}
#rc-booking-app .rc-calendar-wrap {
	margin-bottom: 16px;
}
/* Flatpickr overrides for availability colours */
#rc-booking-app .rc-calendar-wrap .flatpickr-day.rc-avail {
	background: var(--rcb-success-light);
}
#rc-booking-app .rc-calendar-wrap .flatpickr-day.rc-few {
	background: var(--rcb-warning-light);
}
#rc-booking-app .rc-calendar-wrap .flatpickr-day.rc-none {
	background: var(--rcb-gray-100);
	color: var(--rcb-gray-300);
	pointer-events: none;
}
#rc-booking-app .rc-calendar-wrap .flatpickr-day.rc-holiday {
	background: var(--rcb-danger-light);
	color: var(--rcb-danger);
	pointer-events: none;
	text-decoration: line-through;
}
#rc-booking-app .rc-availability-legend {
	display: flex !important;
	gap: 16px;
	flex-wrap: wrap;
	font-size: 13px !important;
	margin-bottom: 16px !important;
}
#rc-booking-app .rc-legend::before {
	content: '';
	display: inline-block;
	width: 12px;
	height: 12px;
	border-radius: 2px;
	margin-right: 4px;
	vertical-align: middle;
}
#rc-booking-app .rc-legend--available::before { background: var(--rcb-success-light); border: 1px solid var(--rcb-success); }
#rc-booking-app .rc-legend--few::before { background: var(--rcb-warning-light); border: 1px solid var(--rcb-warning); }
#rc-booking-app .rc-legend--unavailable::before { background: var(--rcb-gray-100); border: 1px solid var(--rcb-gray-300); }
#rc-booking-app .rc-legend--holiday::before { background: var(--rcb-danger-light); border: 1px solid var(--rcb-danger); }

#rc-booking-app .rc-date-summary {
	background: var(--rcb-gray-50) !important;
	border: 1px solid var(--rcb-gray-200) !important;
	border-radius: var(--rcb-radius-sm) !important;
	padding: 12px 16px !important;
}
#rc-booking-app .rc-date-summary p {
	margin: 4px 0 !important;
}

/* ─────────────────────────────────────────────
 * Options (Step 3)
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-options-list {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
#rc-booking-app .rc-option-item {
	display: flex !important;
	align-items: center !important;
	gap: 14px !important;
	background: var(--rcb-white) !important;
	border: 1.5px solid var(--rcb-gray-200) !important;
	border-radius: var(--rcb-radius) !important;
	padding: 16px 20px !important;
	cursor: pointer;
	transition: all var(--rcb-transition);
	box-shadow: var(--rcb-shadow);
}
#rc-booking-app .rc-option-item:hover {
	border-color: #FFB347 !important;
	box-shadow: var(--rcb-shadow-md);
}
#rc-booking-app .rc-option-item--checked {
	border-color: var(--rcb-primary) !important;
	background: var(--rcb-primary-light) !important;
}
#rc-booking-app .rc-option-item input[type="checkbox"] {
	width: 18px !important;
	height: 18px !important;
	flex-shrink: 0;
	accent-color: var(--rcb-primary);
}
#rc-booking-app .rc-option-item__info {
	flex: 1;
}
#rc-booking-app .rc-option-item__name {
	font-weight: 600 !important;
	font-size: 15px !important;
	color: var(--rcb-gray-900) !important;
}
#rc-booking-app .rc-option-item__desc {
	font-size: 13px !important;
	color: var(--rcb-gray-500) !important;
}
#rc-booking-app .rc-option-item__price {
	font-weight: 600 !important;
	color: var(--rcb-primary) !important;
	white-space: nowrap;
	font-size: 15px !important;
}
#rc-booking-app .rc-options-subtotal {
	margin-top: 12px !important;
	text-align: right;
	font-size: 16px !important;
}

/* ─────────────────────────────────────────────
 * Customer Form (Step 4)
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-form-group {
	margin-bottom: 16px !important;
}
#rc-booking-app .rc-form-group label {
	display: block !important;
	font-weight: 600 !important;
	margin-bottom: 6px !important;
	font-size: 14px !important;
	color: var(--rcb-gray-900) !important;
}
#rc-booking-app .rc-form-group .required {
	color: var(--rcb-danger) !important;
}
#rc-booking-app .rc-input {
	width: 100% !important;
	padding: 10px 12px !important;
	border: 1.5px solid var(--rcb-gray-300) !important;
	border-radius: var(--rcb-radius-sm) !important;
	font-size: 15px !important;
	font-family: inherit !important;
	transition: border-color var(--rcb-transition), box-shadow var(--rcb-transition);
	background: #FAFAF7 !important;
	color: var(--rcb-gray-900) !important;
	line-height: 1.5 !important;
}
#rc-booking-app .rc-input:focus {
	outline: none !important;
	border-color: var(--rcb-primary) !important;
	box-shadow: 0 0 0 3px rgba(247,147,30,.12) !important;
	background: #fff !important;
}
#rc-booking-app .rc-input--error {
	border-color: var(--rcb-danger) !important;
}
#rc-booking-app .rc-input--error:focus {
	box-shadow: 0 0 0 3px rgba(220,38,38,.12) !important;
}
#rc-booking-app .rc-field-error {
	color: var(--rcb-danger) !important;
	font-size: 13px !important;
	margin-top: 4px !important;
}
#rc-booking-app textarea.rc-input {
	resize: vertical;
	min-height: 80px;
}
/* Two-column row for short fields (zip + license) */
#rc-booking-app .rc-form-row {
	display: flex !important;
	gap: 12px !important;
}
#rc-booking-app .rc-form-group--half {
	flex: 1 !important;
	min-width: 0 !important;
}

/* ─────────────────────────────────────────────
 * Payment Methods (Step 5)
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-payment-methods {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	margin-bottom: 20px !important;
}
#rc-booking-app .rc-payment-method {
	display: flex !important;
	align-items: center !important;
	gap: 16px !important;
	padding: 20px 24px !important;
	border: 1.5px solid var(--rcb-gray-200) !important;
	border-radius: var(--rcb-radius) !important;
	cursor: pointer;
	transition: all var(--rcb-transition);
	box-shadow: var(--rcb-shadow);
	background: var(--rcb-white) !important;
}
#rc-booking-app .rc-payment-method:hover {
	border-color: #FFB347 !important;
	box-shadow: var(--rcb-shadow-md);
}
#rc-booking-app .rc-payment-method--selected {
	border-color: var(--rcb-primary) !important;
	background: var(--rcb-primary-light) !important;
}
#rc-booking-app .rc-payment-method input[type="radio"] {
	width: 18px !important;
	height: 18px !important;
	flex-shrink: 0;
	accent-color: var(--rcb-primary);
}
#rc-booking-app .rc-payment-method__label {
	font-weight: 600 !important;
	color: var(--rcb-gray-900) !important;
}
#rc-booking-app .rc-payment-method__desc {
	font-size: 13px !important;
	color: var(--rcb-gray-500) !important;
}
#rc-booking-app .rc-card-container {
	margin-top: 16px !important;
	padding: 16px !important;
	border: 1px solid var(--rcb-gray-200) !important;
	border-radius: var(--rcb-radius-sm) !important;
	background: var(--rcb-gray-50) !important;
}
#rc-booking-app .rc-card-container label {
	display: block !important;
	font-weight: 600 !important;
	margin-bottom: 8px !important;
	font-size: 14px !important;
}
#rc-booking-app #rc-square-card {
	min-height: 44px;
}
#rc-booking-app .rc-card-note {
	font-size: 12px !important;
	color: var(--rcb-gray-500) !important;
	margin-top: 8px !important;
}

/* ─────────────────────────────────────────────
 * Confirmation (Step 6) — polished card layout
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-confirm-card {
	background: var(--rcb-white) !important;
	border: 1.5px solid var(--rcb-gray-200) !important;
	border-radius: var(--rcb-radius) !important;
	padding: 0 !important;
	box-shadow: var(--rcb-shadow-md) !important;
	overflow: hidden !important;
	margin-bottom: 20px !important;
}

/* ── Section container ── */
#rc-booking-app .rc-confirm-section {
	margin: 0 !important;
	padding: 0 !important;
	border-bottom: 1px solid var(--rcb-gray-200) !important;
}
#rc-booking-app .rc-confirm-section:last-of-type {
	border-bottom: none !important;
}

/* ── Section header with icon ── */
#rc-booking-app .rc-confirm-section__header {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	padding: 14px 24px !important;
	background: var(--rcb-primary-light) !important;
	font-size: 15px !important;
	font-weight: 700 !important;
	color: var(--rcb-gray-900) !important;
	border-bottom: 1px solid var(--rcb-gray-200) !important;
	letter-spacing: 0.02em !important;
}
#rc-booking-app .rc-confirm-section__icon {
	font-size: 18px !important;
	line-height: 1 !important;
	flex-shrink: 0 !important;
}

/* ── Section body ── */
#rc-booking-app .rc-confirm-section__body {
	padding: 4px 0 !important;
}

/* ── Row: label + value ── */
#rc-booking-app .rc-confirm-row {
	display: flex !important;
	justify-content: space-between !important;
	align-items: baseline !important;
	padding: 10px 24px !important;
	font-size: 14px !important;
	border-bottom: 1px dashed rgba(0,0,0,.06) !important;
	margin: 0 !important;
	transition: background .15s ease !important;
}
#rc-booking-app .rc-confirm-row:last-child {
	border-bottom: none !important;
}
#rc-booking-app .rc-confirm-row:hover {
	background: rgba(247,147,30,.03) !important;
}

/* Row label */
#rc-booking-app .rc-confirm-row__label {
	color: var(--rcb-gray-500) !important;
	font-weight: 500 !important;
	font-size: 13px !important;
	flex-shrink: 0 !important;
	min-width: 80px !important;
	padding-right: 16px !important;
}

/* Row value */
#rc-booking-app .rc-confirm-row__value {
	margin: 0 !important;
	font-weight: 600 !important;
	color: var(--rcb-gray-900) !important;
	text-align: right !important;
	word-break: break-word !important;
}

/* Highlight variant (subtotals) */
#rc-booking-app .rc-confirm-row--highlight {
	background: var(--rcb-gray-50) !important;
}
#rc-booking-app .rc-confirm-row--highlight .rc-confirm-row__label {
	font-weight: 700 !important;
	color: var(--rcb-gray-700) !important;
}
#rc-booking-app .rc-confirm-row--highlight .rc-confirm-row__value {
	color: var(--rcb-primary) !important;
	font-weight: 800 !important;
	font-size: 15px !important;
}

/* ── Grand total bar ── */
#rc-booking-app .rc-confirm-total {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	padding: 18px 24px !important;
	background: linear-gradient(135deg, #F7931E, #FF9F1C) !important;
	color: #fff !important;
	margin: 0 !important;
}
#rc-booking-app .rc-confirm-total__label {
	font-size: 15px !important;
	font-weight: 700 !important;
	color: #fff !important;
}
#rc-booking-app .rc-confirm-total__value {
	font-size: 28px !important;
	font-weight: 800 !important;
	color: #fff !important;
	letter-spacing: 0.02em !important;
}

/* ── Terms checkbox ── */
#rc-booking-app .rc-terms {
	margin-top: 16px !important;
	font-size: 14px !important;
}
#rc-booking-app .rc-terms label {
	display: flex !important;
	align-items: center !important;
	gap: 8px !important;
	cursor: pointer;
	font-weight: normal !important;
}
#rc-booking-app .rc-terms a {
	color: var(--rcb-primary) !important;
}

/* ─────────────────────────────────────────────
 * Completion (Step 7)
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-complete {
	text-align: center !important;
	padding: 32px 16px !important;
}
#rc-booking-app .rc-complete__icon {
	width: 80px !important;
	height: 80px !important;
	border-radius: 50% !important;
	background: linear-gradient(135deg, #7ACB6D, #5cb85c) !important;
	color: var(--rcb-white) !important;
	font-size: 36px !important;
	line-height: 80px !important;
	margin: 0 auto 20px !important;
	box-shadow: 0 8px 24px rgba(122,203,109,.3);
	display: block !important;
}
#rc-booking-app .rc-complete__title {
	font-size: 22px !important;
	margin: 0 0 12px 0 !important;
	color: var(--rcb-gray-900) !important;
	border: none !important;
	padding: 0 !important;
}
#rc-booking-app .rc-complete__message {
	font-size: 16px !important;
	color: var(--rcb-gray-700) !important;
	margin-bottom: 20px !important;
}
#rc-booking-app .rc-complete__details {
	background: var(--rcb-gray-50) !important;
	border: 1.5px solid var(--rcb-gray-200) !important;
	border-radius: var(--rcb-radius) !important;
	padding: 24px !important;
	text-align: left;
	margin: 0 auto 24px !important;
	max-width: 500px;
	box-shadow: var(--rcb-shadow);
}
#rc-booking-app .rc-complete__details dl {
	display: grid !important;
	grid-template-columns: auto 1fr !important;
	gap: 6px 16px !important;
	margin: 0 !important;
}
#rc-booking-app .rc-complete__details dt {
	font-weight: 600 !important;
	color: var(--rcb-gray-500) !important;
	font-size: 13px !important;
}
#rc-booking-app .rc-complete__details dd {
	margin: 0 !important;
}
#rc-booking-app .rc-complete__note {
	font-size: 14px !important;
	color: var(--rcb-gray-500) !important;
}
#rc-booking-app .rc-complete__contact {
	font-size: 14px !important;
	color: var(--rcb-gray-700) !important;
}

/* ─────────────────────────────────────────────
 * Navigation Buttons
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-nav {
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
	margin-top: 24px !important;
	gap: 12px !important;
	padding: 0 !important;
	border: none !important;
}
#rc-booking-app .rc-btn {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 12px 28px !important;
	border: none !important;
	border-radius: var(--rcb-radius-sm) !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	font-family: inherit !important;
	cursor: pointer;
	transition: background var(--rcb-transition), opacity var(--rcb-transition), transform var(--rcb-transition), box-shadow var(--rcb-transition);
	text-decoration: none !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	line-height: 1.4 !important;
}
#rc-booking-app .rc-btn:disabled {
	opacity: .5;
	cursor: not-allowed;
}
#rc-booking-app .rc-btn--primary {
	background: linear-gradient(135deg, #F7931E, #FF9F1C) !important;
	color: var(--rcb-white) !important;
	border-radius: 9999px !important;
	box-shadow: 0 4px 14px rgba(247,147,30,.35) !important;
}
#rc-booking-app .rc-btn--primary:hover:not(:disabled) {
	background: linear-gradient(135deg, #E07A00, #F7931E) !important;
	transform: translateY(-1px);
	box-shadow: 0 6px 20px rgba(247,147,30,.45) !important;
}
#rc-booking-app .rc-btn--secondary {
	background: var(--rcb-white) !important;
	color: var(--rcb-gray-700) !important;
	border: 1.5px solid var(--rcb-gray-200) !important;
	border-radius: 9999px !important;
}
#rc-booking-app .rc-btn--secondary:hover:not(:disabled) {
	background: var(--rcb-gray-100) !important;
	border-color: var(--rcb-gray-300) !important;
}
#rc-booking-app .rc-btn--confirm {
	background: var(--rcb-success) !important;
	padding: 14px 36px !important;
	font-size: 16px !important;
	border-radius: 9999px !important;
	color: #fff !important;
	box-shadow: 0 4px 14px rgba(22,163,74,.35) !important;
}
#rc-booking-app .rc-btn--confirm:hover:not(:disabled) {
	background: #15803d !important;
}

/* ─────────────────────────────────────────────
 * Loading / Spinner
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-loading {
	text-align: center !important;
	padding: 32px !important;
	color: var(--rcb-gray-500) !important;
}
#rc-booking-app .rc-spinner {
	display: inline-block !important;
	width: 20px !important;
	height: 20px !important;
	border: 2px solid var(--rcb-gray-200) !important;
	border-top-color: #F7931E !important;
	border-radius: 50% !important;
	animation: rcbSpin .6s linear infinite !important;
	vertical-align: middle;
	margin-right: 6px;
	background: none !important;
}
#rc-booking-app .rc-spinner--lg {
	width: 36px !important;
	height: 36px !important;
	border-width: 3px !important;
}
@keyframes rcbSpin {
	to { transform: rotate(360deg); }
}

/* ─────────────────────────────────────────────
 * Overlay
 * ───────────────────────────────────────────── */
#rc-booking-app .rc-overlay {
	position: absolute !important;
	top: 0; left: 0; right: 0; bottom: 0;
	background: rgba(255,255,255,.85) !important;
	display: none !important;
	align-items: center !important;
	justify-content: center !important;
	z-index: 1000;
	border-radius: var(--rcb-radius);
}
#rc-booking-app .rc-overlay.rc-overlay--visible {
	display: flex !important;
}
#rc-booking-app .rc-overlay__content {
	text-align: center !important;
}
#rc-booking-app .rc-overlay__content p {
	margin-top: 12px !important;
	font-weight: 600 !important;
	color: var(--rcb-gray-700) !important;
}

/* ─────────────────────────────────────────────
 * Responsive
 * ───────────────────────────────────────────── */
@media screen and (max-width: 600px) {
	#rc-booking-app.rc-booking {
		padding: 16px !important;
	}
	#rc-booking-app .rc-progress__label {
		font-size: 9px !important;
	}
	#rc-booking-app .rc-progress__num {
		width: 28px !important;
		height: 28px !important;
		font-size: 12px !important;
	}
	#rc-booking-app .rc-vehicle-grid {
		grid-template-columns: 1fr !important;
	}
	#rc-booking-app .rc-date-section {
		grid-template-columns: 1fr !important;
	}
	#rc-booking-app .rc-form-row {
		flex-direction: column !important;
	}
	/* ── Confirmation rows: stay horizontal on mobile ── */
	#rc-booking-app .rc-confirm-row {
		padding: 9px 16px !important;
	}
	#rc-booking-app .rc-confirm-row__label {
		min-width: 70px !important;
		font-size: 12px !important;
	}
	#rc-booking-app .rc-confirm-row__value {
		font-size: 13px !important;
	}
	#rc-booking-app .rc-confirm-section__header {
		padding: 12px 16px !important;
		font-size: 14px !important;
	}
	#rc-booking-app .rc-confirm-total {
		padding: 16px !important;
	}
	#rc-booking-app .rc-confirm-total__value {
		font-size: 24px !important;
	}
	/* ── Nav buttons ── */
	#rc-booking-app .rc-nav {
		flex-direction: column !important;
	}
	#rc-booking-app .rc-btn {
		width: 100% !important;
	}
}

@media screen and (max-width: 400px) {
	#rc-booking-app .rc-progress__label {
		display: none !important;
	}
}
