/* ===========================================
 * DRIVIGO Booking — Corporate Premium Design
 * Extends design-2026.css
 *
 * Design principles:
 * - No emojis anywhere in CSS pseudo-elements
 * - Typography-driven hierarchy (weight, size, spacing)
 * - Gold + dark palette, no green accents
 * - Borders > heavy shadows for refinement
 * - Compact, information-dense layouts
 * =========================================== */

/* ---- Design Tokens ---- */
:root {
    --booking-gold: var(--primary-gold, #ab7d3f);
    --booking-gold-light: var(--gold-light, #c4a265);
    --booking-gold-subtle: #faf6f0;
    --booking-gold-border: rgba(171, 125, 63, 0.30);
    --booking-dark: var(--dark, #1a1a1a);
    --booking-bg: #fafafa;
    --booking-card-bg: #ffffff;
    --booking-border: #c8c0b3;         /* warmer, visible — was #e5e5e5 */
    --booking-border-light: #e0dbd4;   /* visible subtle — was #f0f0f0 */
    --booking-text: #1a1a1a;
    --booking-text-secondary: #3a3a3a; /* darker — was #555 */
    --booking-text-muted: #6b6b6b;     /* readable — was #999 */
    --booking-radius: 10px;
    --booking-radius-sm: 6px;
    --booking-shadow: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
    --booking-shadow-hover: 0 4px 12px rgba(0,0,0,0.08);
    --booking-transition: all 0.2s ease;
}

/* ---- Global Reset ---- */
.booking-page {
    background: var(--booking-bg);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--booking-text);
    -webkit-font-smoothing: antialiased;
    /* Override design-2026 body padding-top (meant for fixed site navbar) */
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* ---- Header ---- */
.booking-header {
    background: var(--booking-dark);
    padding: 0.875rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

.booking-header__logo {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--booking-gold);
    letter-spacing: 2px;
    text-decoration: none;
}

.booking-header__logo:hover {
    color: var(--booking-gold-light);
}

.booking-header__phone {
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 500;
    transition: color 0.2s;
}

.booking-header__phone:hover {
    color: #fff;
}

.booking-header__nav-link {
    color: rgba(255,255,255,0.85);
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 500;
}

.booking-header__account-btn {
    color: #fff;
    border: 1px solid var(--booking-gold);
    padding: 0.4rem 0.75rem;
    font-size: 0.8rem;
    background: transparent;
}

.booking-header__account-btn:hover {
    background: var(--booking-gold);
    color: #fff;
}

/* ---- Alpine x-cloak (hide until Alpine init) ---- */
[x-cloak] {
    display: none !important;
}

/* ---- Progress Bar Wrapper ---- */
.booking-progress-wrap {
    max-width: 1140px;
    margin: 0 auto;
    padding: 1.25rem 1rem 0;
}

/* ---- Footer Compact Variant ---- */
.booking-footer--compact {
    padding: 1.25rem 0;
    margin-top: 2rem;
}

/* ---- Hero Section ---- */
.booking-hero {
    background: linear-gradient(135deg, var(--booking-dark) 0%, #252525 100%);
    padding: 2.5rem 0 2rem;
    color: #fff;
}

.booking-hero__title {
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 800;
    margin-bottom: 0.5rem;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.booking-hero__title span {
    color: var(--booking-gold);
}

.booking-hero__subtitle {
    font-size: 0.95rem;
    color: rgba(255,255,255,0.5);
    max-width: 520px;
    margin: 0 auto;
    font-weight: 400;
}

.booking-hero__badges {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    flex-wrap: wrap;
    font-size: 0.8rem;
    color: rgba(255,255,255,0.6);
    margin-top: 0.75rem;
}

.booking-hero__badges span {
    font-weight: 500;
}

/* ---- Layout ---- */
.booking-layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 1.5rem;
    max-width: 1140px;
    margin: 0 auto;
    padding: 1.5rem 1rem;
    min-height: 70vh;
}

.booking-main {
    min-width: 0;
}

.booking-sidebar {
    position: sticky;
    top: 90px;
    height: fit-content;
}

@media (max-width: 991px) {
    .booking-layout {
        grid-template-columns: 1fr;
    }
    .booking-sidebar {
        position: static;
        order: 1; /* Sidebar AFTER form on mobile — user fills form first */
    }
}

/* ---- Cards ---- */
.booking-card {
    background: var(--booking-card-bg);
    border: 1px solid var(--booking-border);
    border-radius: var(--booking-radius);
    padding: 1.75rem;
    margin-bottom: 1.25rem;
    transition: var(--booking-transition);
}

.booking-card:hover {
    box-shadow: var(--booking-shadow-hover);
}

.booking-card--summary {
    border-color: var(--booking-gold-border);
    background: var(--booking-gold-subtle);
}

.booking-card__title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--booking-text);
    margin-bottom: 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--booking-border-light);
    letter-spacing: -0.01em;
}

/* ---- Section Titles (used inside steps) ---- */
.booking-section-title {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--booking-text);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 0.75rem;
}

/* ---- Info Boxes ---- */
.booking-info {
    background: #f8f9fa;
    border: 1px solid var(--booking-border-light);
    border-radius: var(--booking-radius-sm);
    padding: 0.875rem 1rem;
    font-size: 0.85rem;
    color: var(--booking-text-secondary);
    margin-bottom: 1.25rem;
}

.booking-info strong {
    color: var(--booking-text);
    font-weight: 600;
}

.booking-info--gold {
    background: var(--booking-gold-subtle);
    border-color: var(--booking-gold-border);
}

.booking-info--gold strong {
    color: var(--booking-gold);
}

.booking-info--warning {
    background: #fffbf0;
    border-color: #f0d9a0;
    color: #7a5d20;
}

.booking-info--warning strong {
    color: #5c4516;
}

/* ---- Alerts ---- */
.booking-alert {
    border-radius: var(--booking-radius);
    padding: 1rem 1.25rem;
    font-size: 0.88rem;
    line-height: 1.55;
    margin-bottom: 1.25rem;
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    animation: booking-alert-in 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.booking-alert svg,
.booking-alert__icon { flex-shrink: 0; margin-top: 0.1rem; }

.booking-alert__body { flex: 1; min-width: 0; }

.booking-alert__title {
    font-weight: 700;
    font-size: 0.9rem;
    margin-bottom: 0.15rem;
}

.booking-alert__hint {
    font-size: 0.82rem;
    opacity: 0.8;
    margin-top: 0.25rem;
}

.booking-alert--error {
    background: linear-gradient(135deg, #fef2f2 0%, #fff5f5 100%);
    border: 1px solid #fecaca;
    color: #7f1d1d;
    border-left: 4px solid #ef4444;
}

.booking-alert--success {
    background: linear-gradient(135deg, #f0fdf4 0%, #f7fef9 100%);
    border: 1px solid #bbf7d0;
    color: #14532d;
    border-left: 4px solid #22c55e;
}

.booking-alert--warning {
    background: linear-gradient(135deg, #fffbeb 0%, #fefce8 100%);
    border: 1px solid #fde68a;
    color: #78350f;
    border-left: 4px solid #f59e0b;
}

.booking-alert--info {
    background: linear-gradient(135deg, #eff6ff 0%, #f0f7ff 100%);
    border: 1px solid #bfdbfe;
    color: #1e3a5f;
    border-left: 4px solid #3b82f6;
}

@keyframes booking-alert-in {
    from { opacity: 0; transform: translateY(-8px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ---- Vehicle Cards ---- */
.vehicle-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
}

.vehicle-card {
    border: 1.5px solid var(--booking-border);
    border-radius: var(--booking-radius);
    padding: 1.25rem;
    cursor: pointer;
    transition: var(--booking-transition);
    position: relative;
    background: #fff;
}

.vehicle-card:hover {
    border-color: var(--booking-gold-light);
    box-shadow: var(--booking-shadow-hover);
}

.vehicle-card--selected {
    border-color: var(--booking-gold);
    border-width: 2.5px;
    background: var(--booking-gold-subtle);
    box-shadow: 0 0 0 2px var(--booking-gold-border);
}

.vehicle-card__badge {
    position: absolute;
    top: -8px;
    right: 14px;
    background: var(--booking-gold);
    color: #fff;
    padding: 0.15rem 0.6rem;
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.vehicle-card__name {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0.35rem;
}

.vehicle-card__info {
    color: var(--booking-text-muted);
    font-size: 0.8rem;
    margin-bottom: 0.75rem;
    line-height: 1.4;
}

.vehicle-card__specs {
    display: flex;
    gap: 0.75rem;
    font-size: 0.8rem;
    color: var(--booking-text-secondary);
    margin-bottom: 0.75rem;
}

.vehicle-card__features {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 0.75rem;
}

.vehicle-card__feature {
    font-size: 0.7rem;
    background: var(--booking-border-light);
    padding: 0.15rem 0.5rem;
    border-radius: 3px;
    color: var(--booking-text-secondary);
}

.vehicle-card__price {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--booking-gold);
}

.vehicle-card__price small {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--booking-text-muted);
}

/* ---- Form Elements ---- */
.booking-input {
    width: 100%;
    padding: 0.8rem 1rem;
    border: 1.5px solid var(--booking-border);
    border-radius: var(--booking-radius-sm);
    font-size: 1.05rem; /* ≥16px prevents iOS Safari auto-zoom + readable for seniors */
    line-height: 1.5;
    transition: var(--booking-transition);
    background: #fff;
    color: var(--booking-text);
    -webkit-appearance: none; /* Normalize iOS styling */
    appearance: none;
}

.booking-input:focus {
    border-color: var(--booking-gold);
    border-width: 2px;
    outline: none;
    box-shadow: 0 0 0 3px var(--booking-gold-border);
}

.booking-input--error,
.booking-input.is-invalid {
    border-color: #dc3545;
    animation: booking-shake 0.4s cubic-bezier(0.36, 0.07, 0.19, 0.97);
}

.booking-input.is-invalid:focus {
    box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.12);
}

@keyframes booking-shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-4px); }
    40% { transform: translateX(4px); }
    60% { transform: translateX(-2px); }
    80% { transform: translateX(2px); }
}

/* Valid state (inline @blur validation) */
.booking-input.is-valid {
    border-color: #198754;
}
.booking-input.is-valid:focus {
    box-shadow: 0 0 0 3px rgba(25, 135, 84, 0.12);
}

/* CGV progressive disclosure */
.booking-link--inline {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    color: var(--booking-gold, #c5a355);
    text-decoration: underline;
    cursor: pointer;
}
.booking-link--inline:hover {
    color: var(--booking-gold-hover, #d4b66a);
}

/* CGV policy grid (compact 2-column) */
.booking-policy-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.3rem 1rem;
    font-size: 0.88rem;
}
.booking-policy-grid__label {
    color: var(--booking-text-muted);
}
.booking-policy-grid__value {
    font-weight: 600;
    text-align: right;
}

/* Confirmation tools (calendar + print) */
.booking-confirmation__tools {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    margin: 1.25rem 0;
}
.booking-btn--sm {
    padding: 0.4rem 0.875rem;
    font-size: 0.82rem;
}

/* ---- Return Trip Toggle ---- */
.booking-return-toggle {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
    padding: 0.875rem 1rem;
    border: 1px solid var(--booking-gold-border);
    border-radius: var(--booking-radius-sm, 0.5rem);
    background: var(--booking-gold-subtle);
    transition: border-color 0.2s;
}
.booking-return-toggle:hover {
    border-color: var(--booking-gold);
}
.booking-return-toggle__checkbox {
    margin-top: 0.2rem;
    width: 1.15rem;
    height: 1.15rem;
    accent-color: var(--booking-gold);
    flex-shrink: 0;
    cursor: pointer;
}
.booking-return-toggle__label {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}
.booking-return-toggle__label strong {
    font-size: 0.92rem;
    color: var(--booking-dark);
}
.booking-return-toggle__hint {
    font-size: 0.8rem;
    color: #777;
}

/* Return date/time fields container */
.booking-return-fields {
    padding: 0.875rem 1rem;
    background: var(--booking-gold-subtle);
    border-radius: 0 0 var(--booking-radius-sm, 0.5rem) var(--booking-radius-sm, 0.5rem);
    border: 1px solid var(--booking-gold-border);
    border-top: none;
    margin-top: -0.25rem;
}

/* Travel section separator in merged step 3 */
.booking-options-group--travel {
    border-top: 1px solid var(--booking-border, rgba(255,255,255,0.08));
    padding-top: 1.5rem;
    margin-top: 1.5rem;
}

/* Compact info variant */
.booking-info--compact {
    padding: 0.75rem 1rem;
    font-size: 0.85rem;
}

.booking-label {
    display: block;
    font-weight: 700;
    font-size: 0.95rem;
    margin-bottom: 0.4rem;
    color: var(--booking-text);
}

.booking-label--hint {
    font-weight: 400;
    color: var(--booking-text-muted);
    font-size: 0.82rem;
    margin-top: 0.2rem;
}

.booking-error {
    color: #b91c1c;
    font-size: 0.8rem;
    font-weight: 500;
    margin-top: 0.35rem;
    display: flex;
    align-items: center;
    gap: 0.3rem;
    animation: booking-field-error-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.booking-error::before {
    content: '';
    display: inline-block;
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23b91c1c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='12'/%3E%3Cline x1='12' y1='16' x2='12.01' y2='16'/%3E%3C/svg%3E") center/contain no-repeat;
}

@keyframes booking-field-error-in {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ---- Buttons ---- */
.booking-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.85rem 1.75rem;
    border: none;
    border-radius: var(--booking-radius-sm);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--booking-transition);
    text-decoration: none;
    line-height: 1.4;
    min-height: 48px; /* WCAG touch target */
}

.booking-btn--primary {
    background: var(--booking-gold);
    color: #fff;
}

.booking-btn--primary:hover {
    background: var(--booking-gold-light);
    box-shadow: 0 2px 8px rgba(171, 125, 63, 0.25);
}

.booking-btn--outline {
    background: transparent;
    color: var(--booking-text);
    border: 1.5px solid var(--booking-border);
}

.booking-btn--outline:hover {
    border-color: var(--booking-gold);
    color: var(--booking-gold);
}

.booking-btn--lg {
    padding: 0.875rem 2rem;
    font-size: 0.95rem;
}

.booking-btn--block {
    width: 100%;
}

.booking-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ---- Navigation (prev/next) ---- */
.booking-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 1.75rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--booking-border-light);
}

/* ---- Summary Sidebar ---- */
.booking-summary__row {
    display: flex;
    justify-content: space-between;
    padding: 0.4rem 0;
    font-size: 0.85rem;
    color: var(--booking-text-secondary);
}

/* Small detail rows (options, flight info) */
.booking-summary__row--sm {
    padding: 0.2rem 0;
    font-size: 0.78rem;
    color: var(--booking-text-muted, #777);
}

.booking-summary__row--total {
    border-top: 2px solid var(--booking-gold);
    margin-top: 0.5rem;
    padding-top: 0.75rem;
    font-weight: 800;
    font-size: 1.05rem;
    color: var(--booking-text);
}

.booking-summary__row--total .booking-summary__value {
    color: var(--booking-gold);
    font-size: 1.2rem;
}

/* ---- Data Rows & Payment Options: see enhanced versions below (line ~4330+) ---- */

/* ---- Price Display (big amount box) ---- */
.booking-price-display {
    background: var(--booking-dark);
    color: #fff;
    border-radius: var(--booking-radius);
    padding: 1.25rem;
    margin-bottom: 1.25rem;
    text-align: center;
}

.booking-price-display__label {
    font-size: 0.8rem;
    color: rgba(255,255,255,0.5);
    margin-bottom: 0.25rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.booking-price-display__amount {
    font-size: 2rem;
    font-weight: 800;
    color: var(--booking-gold);
}

.booking-price-display__sub {
    font-size: 0.75rem;
    color: rgba(255,255,255,0.4);
    margin-top: 0.25rem;
}

/* ---- Pill Selector (passengers, toggles) ---- */
.booking-pill {
    padding: 0.45rem 0.75rem;
    border-radius: 20px;
    font-size: 0.8rem;
    cursor: pointer;
    transition: var(--booking-transition);
    background: #fff;
    color: var(--booking-text);
    border: 1px solid var(--booking-border);
    font-weight: 500;
}

.booking-pill:hover {
    border-color: var(--booking-gold-light);
}

.booking-pill--active {
    background: var(--booking-gold);
    color: #fff;
    border-color: var(--booking-gold);
}

.booking-pill--dashed {
    border-style: dashed;
    color: var(--booking-text-muted);
    background: #fafafa;
}

/* ---- Trust Badges (sidebar) ---- */
.booking-trust {
    padding: 1rem;
    font-size: 0.78rem;
    color: var(--booking-text-muted);
}

.booking-trust__item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0;
}

.booking-trust__icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--booking-gold);
    font-weight: 700;
    font-size: 0.75rem;
}

/* ---- Counter Component ---- */
.booking-counter {
    display: inline-flex;
    align-items: center;
    gap: 0;
    border: 1.5px solid var(--booking-border);
    border-radius: var(--booking-radius-sm);
    overflow: hidden;
}

.booking-counter__btn {
    width: 44px;
    height: 44px;
    border: none;
    background: #f5f0e8; /* warm gold-tinted gray */
    font-size: 1.25rem;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--booking-transition);
    color: var(--booking-text);
}

.booking-counter__btn:hover {
    background: var(--booking-gold);
    color: #fff;
}

.booking-counter__value {
    min-width: 48px;
    text-align: center;
    font-weight: 800;
    font-size: 1.1rem;
    background: #fff;
    color: var(--booking-text);
}

/* Editable counter value */
.booking-counter__value--editable {
    cursor: text;
    position: relative;
    border-bottom: 1px dashed rgba(171,125,63,0.3);
    transition: border-color 0.2s ease;
    -webkit-user-select: none;
    user-select: none;
}
.booking-counter__value--editable:hover {
    border-bottom-color: var(--booking-gold, #ab7d3f);
}
.booking-counter__input {
    width: 48px;
    min-width: 48px;
    text-align: center;
    font-weight: 800;
    font-size: 1.1rem;
    background: #fff;
    color: var(--booking-text, #222);
    border: none;
    border-bottom: 2px solid var(--booking-gold, #ab7d3f);
    outline: none;
    padding: 0;
    line-height: inherit;
    font-family: inherit;
    -moz-appearance: textfield;
    appearance: textfield;
}
.booking-counter__input::-webkit-inner-spin-button,
.booking-counter__input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.booking-counter--sm .booking-counter__input {
    width: 28px;
    min-width: 28px;
    font-size: 0.85rem;
}

/* Price flash animation */
@keyframes booking-price-flash {
    0% { opacity: 1; }
    30% { opacity: 0.4; transform: scale(0.96); }
    100% { opacity: 1; transform: scale(1); }
}
.booking-price--flash {
    animation: booking-price-flash 0.4s ease;
}

/* Smooth vehicle row transitions */
.vehicle-row {
    transition: opacity 0.25s ease, transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
.vehicle-row--disabled {
    opacity: 0.4;
    pointer-events: none;
    transform: scale(0.98);
}

/* ---- CGV Checkbox ---- */
.booking-cgv {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem 1.125rem;
    background: #f8f6f2;
    border: 1.5px solid var(--booking-border);
    border-radius: var(--booking-radius-sm);
    margin: 1.25rem 0;
}

.booking-cgv input[type="checkbox"] {
    width: 22px;
    height: 22px;
    margin-top: 2px;
    accent-color: var(--booking-gold);
    flex-shrink: 0;
    cursor: pointer;
}

.booking-cgv label {
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--booking-text-secondary);
}

.booking-cgv a {
    color: var(--booking-gold);
    text-decoration: underline;
}

.booking-cgv--error {
    border-color: #dc3545;
    background: #fef2f2;
}

/* ---- Loading ---- */
.booking-loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: transparent;
    z-index: 9998;
    pointer-events: none;
}

.booking-loader.active::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 30%;
    background: var(--booking-gold);
    animation: booking-loading 1.2s ease infinite;
}

@keyframes booking-loading {
    0% { left: -30%; }
    100% { left: 100%; }
}

/* ---- Toast Notifications ---- */
.booking-toast-container {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    pointer-events: none;
}

@media (max-width: 576px) {
    .booking-toast-container {
        bottom: auto;
        top: 12px;
        right: 12px;
        left: 12px;
        align-items: stretch;
    }
}

.booking-toast {
    pointer-events: auto;
    padding: 0.9rem 1.15rem;
    border-radius: 14px;
    color: #fff;
    font-size: 0.85rem;
    font-weight: 500;
    line-height: 1.4;
    box-shadow: 0 8px 32px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.08);
    animation: booking-toast-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    max-width: 400px;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(8px);
    cursor: pointer;
}

.booking-toast::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: rgba(255,255,255,0.4);
    animation: booking-toast-timer 4s linear forwards;
    border-radius: 0 0 14px 14px;
}

.booking-toast--error::after { animation-duration: 8s; }

.booking-toast svg { flex-shrink: 0; }

.booking-toast__dismiss {
    flex-shrink: 0;
    margin-left: auto;
    background: none;
    border: none;
    color: rgba(255,255,255,0.75);
    font-size: 1.1rem;
    cursor: pointer;
    padding: 0 0.1rem;
    line-height: 1;
    transition: color 0.2s;
}
.booking-toast__dismiss:hover { color: #fff; }

.booking-toast--info { background: rgba(30,30,30,0.92); }
.booking-toast--success { background: rgba(34,120,60,0.94); }
.booking-toast--error { background: rgba(185,28,28,0.94); }
.booking-toast--warning { background: rgba(146,100,10,0.94); color: #fefce8; }

.booking-toast--fade {
    opacity: 0;
    transform: translateX(20px) scale(0.95);
    transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

@media (max-width: 576px) {
    .booking-toast--fade {
        transform: translateY(-10px) scale(0.95);
    }
}

@keyframes booking-toast-in {
    from { opacity: 0; transform: translateY(12px) scale(0.92); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes booking-toast-timer {
    from { width: 100%; }
    to { width: 0%; }
}

/* ---- Spinner ---- */
.booking-spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255,255,255,0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: booking-spin 0.6s linear infinite;
}

@keyframes booking-spin {
    to { transform: rotate(360deg); }
}

/* ---- Map Container ---- */
.booking-map {
    width: 100%;
    height: 320px;
    border-radius: var(--booking-radius);
    overflow: hidden;
    margin: 1rem 0;
    background: #eee;
    border: 1px solid var(--booking-border);
}

@media (max-width: 768px) {
    .booking-map {
        height: 220px;
    }
}

/* ---- Mobile Sticky Bar ---- */
@media (max-width: 768px) {
    .booking-mobile-bar {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: #fff;
        border-top: 1px solid var(--booking-border);
        padding: 0.65rem 1rem;
        z-index: 1000;
        display: flex;
        justify-content: space-between;
        align-items: center;
        box-shadow: 0 -2px 8px rgba(0,0,0,0.06);
    }

    .booking-mobile-bar__price {
        font-size: 1.35rem;
        font-weight: 800;
        color: var(--booking-gold);
    }

    body {
        padding-bottom: 70px;
    }
}

@media (min-width: 769px) {
    .booking-mobile-bar {
        display: none;
    }
}

/* ---- Page Header (Account pages) ---- */
.booking-page-header {
    text-align: center;
    margin-bottom: 1.75rem;
}

.booking-page-header__title {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--booking-text);
    letter-spacing: -0.01em;
}

.booking-page-header__subtitle {
    color: var(--booking-text-muted);
    font-size: 0.95rem;
    margin-top: 0.25rem;
    line-height: 1.5;
}

/* ---- Metric Badge (distance, duration, date) ---- */
.booking-metric {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 0.875rem;
    background: var(--booking-gold-subtle);
    border: 1px solid var(--booking-gold-border);
    border-radius: var(--booking-radius-sm);
}

.booking-metric__label {
    font-size: 0.75rem;
    color: var(--booking-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.booking-metric__value {
    font-weight: 700;
    color: var(--booking-text);
    font-size: 1rem;
}

/* ---- Options Group ---- */
.booking-options-group {
    background: #f8f9fa;
    border: 1px solid var(--booking-border-light);
    border-radius: var(--booking-radius);
    padding: 1.25rem;
    margin-bottom: 1.25rem;
}

.booking-options-group__title {
    font-size: 0.9rem;
    font-weight: 700;
    margin-bottom: 0.875rem;
    color: var(--booking-text);
}

/* ---- Price Breakdown ---- */
.booking-price-breakdown {
    background: var(--booking-gold-subtle);
    border: 1px solid var(--booking-gold-border);
    border-radius: var(--booking-radius);
    padding: 1rem;
    margin-bottom: 1.25rem;
}

.booking-price-breakdown hr {
    border-color: var(--booking-gold-border);
    margin: 0.5rem 0;
}

/* ---- Auth Modal ---- */
.booking-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.booking-modal {
    background: var(--booking-card-bg, #1e1e1e);
    border: 1px solid var(--booking-border, rgba(255,255,255,0.08));
    border-radius: 1rem;
    padding: 2rem;
    padding-bottom: max(2rem, env(safe-area-inset-bottom));
    max-width: 440px;
    width: 100%;
    position: relative;
    max-height: 90vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.booking-modal__close {
    position: absolute;
    top: 0.75rem;
    right: 1rem;
    background: none;
    border: none;
    color: var(--booking-text-secondary, #3a3a3a);
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
    padding: 0.25rem;
    transition: color 0.2s ease;
}
.booking-modal__close:hover {
    color: var(--booking-text, #fff);
}

.booking-modal__header {
    text-align: center;
    margin-bottom: 1.5rem;
}

.booking-modal__title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--booking-text, #fff);
    margin-bottom: 0.5rem;
}

.booking-modal__subtitle {
    font-size: 0.85rem;
    color: var(--booking-text-secondary, #3a3a3a);
    margin: 0;
}

.booking-modal__tabs {
    display: flex;
    gap: 0;
    margin-bottom: 1.25rem;
    border-bottom: 1px solid var(--booking-border, rgba(255,255,255,0.08));
}

.booking-modal__tab {
    flex: 1;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--booking-text-secondary, #3a3a3a);
    padding: 0.75rem 0.5rem;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}

.booking-modal__tab--active {
    color: var(--booking-gold, #c5a355);
    border-bottom-color: var(--booking-gold, #c5a355);
}

.booking-modal__tab:hover:not(.booking-modal__tab--active) {
    color: var(--booking-text, #fff);
}

.booking-modal__privacy {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid var(--booking-border-light, rgba(255,255,255,0.1));
    font-size: 0.75rem;
    color: var(--booking-text-muted, #6b6b6b);
    text-align: center;
    line-height: 1.3;
}

.booking-modal-enter {
    transition: opacity 0.2s ease;
}
.booking-modal-leave {
    transition: opacity 0.15s ease;
}

@media (max-width: 480px) {
    .booking-modal {
        padding: 1.25rem;
        border-radius: 0.75rem;
    }
}

/* ---- Footer ---- */
.booking-footer {
    background: var(--booking-dark);
    color: rgba(255,255,255,0.5);
    padding: 1.75rem 0;
    margin-top: 2.5rem;
    font-size: 0.82rem;
}

.booking-footer a {
    color: rgba(255,255,255,0.5);
    transition: color 0.2s;
}

.booking-footer a:hover {
    color: var(--booking-gold);
}

.booking-footer__heading {
    color: #fff;
    font-weight: 600;
    font-size: 0.85rem;
    margin-bottom: 0.5rem;
}

.booking-footer__brand {
    color: var(--booking-gold);
    font-weight: 700;
}

.booking-footer hr {
    border-color: rgba(255,255,255,0.08);
}

/* ---- Password Toggle ---- */
.booking-pw-toggle {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    transition: color 0.2s ease;
    cursor: pointer;
    color: var(--booking-text-muted);
    font-size: 0.85rem;
    font-weight: 500;
    padding: 0.2rem;
}

.booking-pw-toggle:hover {
    color: var(--booking-text);
}

/* ---- Stat Badge (route badges) ---- */
.booking-stat-box {
    background: #f8f9fa;
    border: 1px solid var(--booking-border-light);
    border-radius: var(--booking-radius-sm);
    padding: 0.875rem 1rem;
}

.booking-stat-box__label {
    font-size: 0.7rem;
    color: var(--booking-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.booking-stat-box__value {
    font-weight: 700;
    color: var(--booking-text);
    margin-top: 0.15rem;
}

/* ===========================================
 * UX IMPROVEMENTS — Accessibility, States, Feedback
 * =========================================== */

/* ---- Skip Link (Accessibility) ---- */
.booking-skip-link {
    position: absolute;
    top: -100px;
    left: 0;
    background: var(--booking-gold);
    color: #fff;
    padding: 0.5rem 1rem;
    z-index: 10001;
    font-size: 0.85rem;
    font-weight: 600;
    border-radius: 0 0 var(--booking-radius-sm) 0;
    transition: top 0.2s ease;
}

.booking-skip-link:focus {
    top: 0;
    outline: 2px solid #fff;
    outline-offset: 2px;
}

/* ---- Required Field Indicator ---- */
.booking-label--required::after {
    content: ' *';
    color: #dc3545;
    font-weight: 400;
}

/* ---- Improved Disabled Button State ---- */
.booking-btn:disabled,
.booking-btn[aria-disabled="true"] {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
    filter: grayscale(30%);
}

/* ---- Focus Visible Ring (keyboard navigation) ---- */
.booking-btn:focus-visible {
    outline: 2px solid var(--booking-gold);
    outline-offset: 2px;
}

.booking-input:focus-visible {
    outline: none;
    border-color: var(--booking-gold);
    box-shadow: 0 0 0 3px var(--booking-gold-border);
}

.booking-pill:focus-visible,
.vehicle-card:focus-visible {
    outline: 2px solid var(--booking-gold);
    outline-offset: 2px;
}

.booking-payment-option:focus-within {
    border-color: var(--booking-gold);
    background: var(--booking-gold-subtle);
}

/* ---- Spinner in Buttons ---- */
.booking-btn .booking-spinner {
    width: 14px;
    height: 14px;
    border-width: 2px;
    margin-right: 0.35rem;
}

.booking-btn--outline .booking-spinner {
    border-color: rgba(0,0,0,0.15);
    border-top-color: var(--booking-gold);
}

/* ---- Counter Boundary States ---- */
.booking-counter__btn[disabled],
.booking-counter__btn--disabled {
    opacity: 0.3;
    cursor: not-allowed;
    pointer-events: none;
}

.booking-counter__btn[disabled]:hover {
    background: #f8f9fa;
    color: var(--booking-text);
}

/* ---- Inline Form Card (login inside step-5) ---- */
.booking-inline-form {
    background: #f8f6f2;
    border: 1.5px solid var(--booking-border);
    border-radius: var(--booking-radius);
    padding: 1.25rem;
    margin-bottom: 1rem;
}

/* ---- Saved Passenger Card ---- */
.booking-saved-passenger {
    padding: 0.875rem 1rem;
    border: 1.5px solid var(--booking-border);
    border-radius: var(--booking-radius-sm);
    cursor: pointer;
    transition: var(--booking-transition);
    background: #fff;
}

.booking-saved-passenger:hover {
    border-color: var(--booking-gold-light);
}

.booking-saved-passenger--selected {
    border-color: var(--booking-gold);
    background: var(--booking-gold-subtle);
}

/* ---- Helper text (muted small) ---- */
.booking-hint {
    font-size: 0.85rem;
    color: var(--booking-text-muted);
    margin-left: 0.75rem;
    line-height: 1.5;
}

/* ---- Price accent ---- */
.booking-price-accent {
    color: var(--booking-gold);
    font-weight: 600;
}

/* ---- Options Price Summary ---- */
.booking-price-summary-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
}

.booking-price-summary-total {
    display: flex;
    justify-content: space-between;
    font-weight: 800;
    font-size: 1.05rem;
}

/* ---- Form Error with aria-live ---- */
.booking-error[aria-live] {
    min-height: 1.2em;
}

/* ---- Toast Accessibility ---- */
.booking-toast[role="alert"] {
    /* Ensures screen readers announce */
}

/* ---- Confirmation Success Emphasis ---- */
.booking-alert--success-lg {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    color: #166534;
    border-radius: var(--booking-radius);
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.25rem;
    text-align: center;
}

.booking-alert--success-lg .booking-alert__title {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.booking-alert--success-lg .booking-alert__message {
    font-size: 1rem;
    color: #166534;
    opacity: 0.85;
}

/* ---- Link Hover/Focus States ---- */
a[style*="booking-gold"]:hover,
.booking-link:hover {
    opacity: 0.85;
}

.booking-link {
    color: var(--booking-gold);
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: opacity 0.2s;
}

.booking-link:focus-visible {
    outline: 2px solid var(--booking-gold);
    outline-offset: 2px;
    border-radius: 2px;
}

/* ---- Animation: step content fade in ---- */
@keyframes booking-step-in {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

#booking-content > .booking-card {
    animation: booking-step-in 0.3s ease;
}

/* ---- Responsive padding improvements ---- */
@media (max-width: 576px) {
    .booking-card {
        padding: 1.25rem;
    }
    .booking-options-group {
        padding: 1rem;
    }
    .booking-hero {
        padding: 1.75rem 0 1.5rem;
    }
}

/* ===========================================
 * UX PHASE 2 — Skeleton Loading, Confirmation,
 * Micro-interactions, Mobile, Session Recovery
 * =========================================== */

/* ---- Skeleton Loading (HTMX step transitions) ---- */
.booking-skeleton {
    padding: 1.75rem;
    background: var(--booking-card-bg);
    border: 1px solid var(--booking-border);
    border-radius: var(--booking-radius);
}

.booking-skeleton__line {
    height: 14px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: booking-shimmer 1.5s ease infinite;
    border-radius: 4px;
    margin-bottom: 0.75rem;
}

.booking-skeleton__line--title {
    height: 22px;
    width: 55%;
    margin-bottom: 1.25rem;
}

.booking-skeleton__line--short { width: 40%; }
.booking-skeleton__line--medium { width: 70%; }
.booking-skeleton__line--long { width: 90%; }
.booking-skeleton__line--full { width: 100%; }

.booking-skeleton__block {
    height: 120px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: booking-shimmer 1.5s ease infinite;
    border-radius: var(--booking-radius-sm);
    margin-bottom: 0.75rem;
}

.booking-skeleton__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
}

.booking-skeleton__message {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--booking-text-secondary, #7a7a73);
    text-align: center;
    margin-bottom: 1.25rem;
    letter-spacing: 0.01em;
}

@keyframes booking-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ---- Confirmation Page Components ---- */
.booking-confirmation {
    text-align: center;
    padding: 2rem 1.5rem 2.5rem;
}

.booking-confirmation__icon {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.25rem;
    font-size: 1.75rem;
    font-weight: 800;
}

.booking-confirmation__icon--success {
    background: linear-gradient(135deg, #dcfce7, #bbf7d0);
    color: #166534;
    border: 2px solid #86efac;
    box-shadow: 0 4px 16px rgba(22,101,52,0.12);
}

.booking-confirmation__icon--error {
    background: linear-gradient(135deg, #fef2f2, #fecaca);
    color: #991b1b;
    border: 2px solid #fca5a5;
    box-shadow: 0 4px 16px rgba(153,27,27,0.1);
}

.booking-confirmation__icon--warning {
    background: linear-gradient(135deg, #fffbeb, #fed7aa);
    color: #92400e;
    border: 2px solid #fdba74;
    box-shadow: 0 4px 16px rgba(146,64,14,0.1);
}

.booking-confirmation__icon--info {
    background: linear-gradient(135deg, #faf6f0, #f0e6d2);
    color: var(--booking-gold, #ab7d3f);
    border: 2px solid var(--booking-gold-border, #e5d5b8);
    box-shadow: 0 4px 16px rgba(171,125,63,0.12);
}

/* Animated SVG checkmark */
.booking-checkmark__circle {
    stroke-dasharray: 151;
    stroke-dashoffset: 151;
    animation: booking-checkmark-circle 0.6s ease forwards;
}
.booking-checkmark__check {
    stroke-dasharray: 36;
    stroke-dashoffset: 36;
    animation: booking-checkmark-draw 0.4s 0.4s ease forwards;
}
@keyframes booking-checkmark-circle {
    to { stroke-dashoffset: 0; }
}
@keyframes booking-checkmark-draw {
    to { stroke-dashoffset: 0; }
}

/* CGV cancellation grid */
.booking-cgv-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
    text-align: left;
    margin: 1rem 0;
}
.booking-cgv-grid__item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    background: var(--booking-bg-subtle, #f8f7f5);
    font-size: 0.85rem;
}
.booking-cgv-grid__item span:first-child { color: var(--booking-text-secondary); }
.booking-cgv-grid__item strong { font-weight: 700; }
@media (max-width: 480px) {
    .booking-cgv-grid { grid-template-columns: 1fr; }
}

.booking-confirmation__title {
    font-size: 1.5rem;
    font-weight: 800;
    margin-bottom: 0.5rem;
    letter-spacing: -0.02em;
}

.booking-confirmation__title--success { color: #166534; }
.booking-confirmation__title--error { color: #991b1b; }
.booking-confirmation__title--warning { color: #92400e; }
.booking-confirmation__title--info { color: #1e40af; }

.booking-confirmation__desc {
    color: var(--booking-text-secondary);
    font-size: 1rem;
    margin-bottom: 1.75rem;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
}

.booking-confirmation__ref {
    background: var(--booking-gold-subtle);
    border: 1px solid var(--booking-gold-border);
    border-radius: var(--booking-radius);
    padding: 1rem 1.5rem;
    margin-bottom: 1.75rem;
    display: inline-block;
}

.booking-confirmation__ref-label {
    font-size: 0.75rem;
    color: var(--booking-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.booking-confirmation__ref-value {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--booking-gold);
    letter-spacing: 2px;
}

.booking-confirmation__actions {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    flex-wrap: wrap;
}

/* ---- Payment Redirect Card ---- */
.booking-payment-redirect {
    text-align: center;
    padding: 2.5rem 1.5rem;
}

.booking-payment-redirect__spinner {
    width: 52px;
    height: 52px;
    border: 3px solid var(--booking-border);
    border-top-color: var(--booking-gold);
    border-radius: 50%;
    animation: booking-spin 0.8s linear infinite;
    margin: 0 auto 1.5rem;
}

.booking-payment-redirect__title {
    font-size: 1.2rem;
    font-weight: 800;
    margin-bottom: 0.5rem;
}

.booking-payment-redirect__desc {
    color: var(--booking-text-secondary);
    font-size: 0.95rem;
    margin-bottom: 1.25rem;
}

.booking-payment-redirect__amount {
    background: #f8f9fa;
    border-radius: var(--booking-radius);
    padding: 1rem 1.5rem;
    margin-bottom: 1.5rem;
    display: inline-block;
}

.booking-payment-redirect__amount-label {
    font-size: 0.75rem;
    color: var(--booking-text-muted);
}

.booking-payment-redirect__amount-value {
    font-size: 1.8rem;
    font-weight: 800;
    color: var(--booking-gold);
}

.booking-payment-redirect__amount-note {
    font-size: 0.75rem;
    color: var(--booking-text-muted);
}

.booking-payment-redirect__countdown {
    font-size: 0.85rem;
    color: var(--booking-text-muted);
    margin-bottom: 1.5rem;
}

.booking-payment-redirect__secure {
    font-size: 0.75rem;
    color: var(--booking-text-muted);
    margin-top: 0.75rem;
}

/* ---- Bank Transfer Details ---- */
.booking-bank-details {
    text-align: left;
}

.booking-bank-details__title {
    font-size: 0.95rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.booking-bank-details__row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
    font-size: 0.85rem;
    color: var(--booking-text-secondary);
}

.booking-bank-details__row strong {
    color: var(--booking-text);
}

.booking-bank-details__row--mono strong {
    font-family: 'Courier New', monospace;
    letter-spacing: 1px;
}

/* ---- Next Steps List ---- */
.booking-steps-list {
    text-align: left;
    padding-left: 1.25rem;
    margin: 0.5rem 0 0;
    color: var(--booking-text-secondary);
}

.booking-steps-list li {
    margin-bottom: 0.4rem;
    font-size: 0.88rem;
}

/* ---- Password Strength Indicator ---- */
.booking-pw-strength {
    display: flex;
    gap: 4px;
    margin-top: 0.5rem;
}

.booking-pw-strength__bar {
    height: 3px;
    flex: 1;
    border-radius: 2px;
    background: var(--booking-border);
    transition: background 0.3s ease;
}

.booking-pw-strength__bar--weak { background: #ef4444; }
.booking-pw-strength__bar--fair { background: #f59e0b; }
.booking-pw-strength__bar--good { background: #22c55e; }
.booking-pw-strength__bar--strong { background: #16a34a; }

.booking-pw-strength__label {
    font-size: 0.7rem;
    margin-top: 0.2rem;
    font-weight: 500;
}

.booking-pw-strength__label--weak { color: #ef4444; }
.booking-pw-strength__label--fair { color: #f59e0b; }
.booking-pw-strength__label--good { color: #22c55e; }
.booking-pw-strength__label--strong { color: #16a34a; }

/* ---- Session Recovery Banner ---- */
.booking-session-banner {
    background: var(--booking-gold-subtle);
    border: 1px solid var(--booking-gold-border);
    border-radius: var(--booking-radius);
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    animation: booking-step-in 0.3s ease;
}

.booking-session-banner__text {
    font-size: 0.88rem;
    color: var(--booking-text);
}

.booking-session-banner__text strong {
    color: var(--booking-gold);
}

.booking-session-banner__actions {
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
}

/* ---- HTMX Retry Bar ---- */
.booking-retry-bar {
    background: linear-gradient(135deg, #fefce8 0%, #fffbeb 50%, #fef2f2 100%);
    border: 1px solid #fde68a;
    border-radius: var(--booking-radius);
    padding: 2rem 1.5rem;
    text-align: center;
    margin-bottom: 1.25rem;
    animation: booking-alert-in 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.booking-retry-bar::before {
    content: '⚠️';
    display: block;
    font-size: 2rem;
    margin-bottom: 0.75rem;
    line-height: 1;
}

.booking-retry-bar__message {
    font-size: 0.92rem;
    color: #78350f;
    margin-bottom: 0.35rem;
    font-weight: 600;
}

.booking-retry-bar__hint {
    font-size: 0.82rem;
    color: #92400e;
    opacity: 0.75;
    margin-bottom: 1rem;
}

/* ---- Input Group (icon + input) ---- */
.booking-input-group {
    position: relative;
}

.booking-input-group .booking-input {
    padding-right: 3rem;
}

.booking-input-group__append {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
}

/* ---- Mobile: Improved Touch Targets ---- */
@media (max-width: 768px) {
    .booking-btn {
        min-height: 48px;
        padding: 0.875rem 1.5rem;
    }

    .booking-counter__btn {
        width: 44px;
        height: 44px;
    }

    .booking-pill {
        padding: 0.6rem 1rem;
        font-size: 0.85rem;
    }

    .booking-payment-option {
        padding: 1.25rem;
    }

    .vehicle-card {
        padding: 1.25rem;
    }

    /* Bottom safe area for sticky bar */
    .booking-mobile-bar {
        padding-bottom: max(0.65rem, env(safe-area-inset-bottom));
    }

    body.booking-page {
        padding-bottom: max(70px, calc(60px + env(safe-area-inset-bottom)));
    }

    /* Slightly larger form inputs on mobile */
    .booking-input {
        padding: 0.8rem 0.875rem;
        font-size: 16px; /* Prevents iOS zoom on focus */
    }

    /* Full width buttons in nav on mobile */
    .booking-nav {
        flex-direction: column-reverse;
        gap: 0.75rem;
    }

    .booking-nav .booking-btn {
        width: 100%;
        justify-content: center;
    }

    /* Confirmation page responsive */
    .booking-confirmation {
        padding: 1.75rem 1rem;
    }

    .booking-confirmation__title {
        font-size: 1.25rem;
    }
}

/* ---- Smooth page transitions ---- */
#booking-content {
    transition: opacity 0.15s ease;
}

.htmx-request #booking-content {
    opacity: 0.5;
    pointer-events: none;
}

/* ---- Form field highlight on focus within ---- */
.booking-card .mb-3:focus-within .booking-label,
.booking-card .mb-4:focus-within .booking-label {
    color: var(--booking-gold);
}

/* ---- Vehicle Card selection ripple ---- */
.vehicle-card::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--booking-radius);
    opacity: 0;
    background: radial-gradient(circle at center, var(--booking-gold-border), transparent 70%);
    transition: opacity 0.3s ease;
    pointer-events: none;
}

.vehicle-card--selected::after {
    opacity: 1;
}

/* ---- Tooltip (for small info icons) ---- */
.booking-tooltip {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--booking-border);
    color: var(--booking-text-muted);
    font-size: 0.65rem;
    font-weight: 700;
    cursor: help;
    margin-left: 0.35rem;
}

.booking-tooltip::after {
    content: attr(data-tip);
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--booking-dark);
    color: #fff;
    padding: 0.4rem 0.65rem;
    border-radius: 4px;
    font-size: 0.72rem;
    font-weight: 400;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s;
    z-index: 10;
}

.booking-tooltip:hover::after,
.booking-tooltip:focus::after {
    opacity: 1;
}

/* ---- Print styles (for confirmation/invoice) ---- */
@media print {
    .booking-header,
    .booking-footer,
    .booking-progress,
    .booking-mobile-bar,
    .booking-sidebar,
    .booking-nav,
    .booking-skip-link,
    .booking-loader {
        display: none !important;
    }

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

    .booking-card {
        border: 1px solid #ddd;
        box-shadow: none;
    }

    body.booking-page {
        background: #fff;
        padding: 0;
    }
}

/* ---- Reduced Motion (accessibility) ---- */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }

    .booking-skeleton__line,
    .booking-skeleton__block {
        animation: none;
        background: #f0f0f0;
    }

    #booking-content > .booking-card {
        animation: none;
    }

    .booking-swap-btn:hover {
        transform: none;
    }

    .vehicle-card--selected {
        animation: none;
    }
}

/* ---- High Contrast Mode ---- */
@media (forced-colors: active) {
    .booking-btn--primary {
        border: 2px solid ButtonText;
    }

    .booking-progress__circle {
        border: 2px solid ButtonText;
    }

    .vehicle-card--selected {
        outline: 3px solid Highlight;
    }
}

/* ===========================================
 * UX PHASE 3 — Inline Style Elimination
 * Semantic classes for sidebar, forms, toggles
 * =========================================== */

/* ---- Card Title Size Variant ---- */
.booking-card__title--sm {
    font-size: 1rem;
}

/* ---- Summary Sidebar Values ---- */
.booking-summary__value {
    font-weight: 500;
}

.booking-summary__value--bold {
    font-weight: 600;
}

.booking-summary__value--address {
    font-weight: 500;
    text-align: right;
    max-width: 200px;
    word-break: break-word;
    overflow-wrap: anywhere;
    font-size: 0.82rem;
    line-height: 1.3;
}

.booking-summary__vehicle {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.5rem 0;
}

.booking-summary__vehicle-img {
    width: 80px;
    height: auto;
    border-radius: 6px;
    object-fit: contain;
}

.booking-summary__value--highlight {
    font-weight: 600;
    color: var(--booking-gold);
}

.booking-summary__divider {
    border-color: var(--booking-gold-border);
    margin: 0.5rem 0;
}

.booking-summary__note {
    font-size: 0.7rem;
    color: var(--booking-text-muted);
    text-align: right;
    margin-top: 0.25rem;
}

.booking-summary__empty {
    text-align: center;
    color: var(--booking-text-muted);
    padding: 1rem 0;
    font-size: 0.82rem;
}

/* ---- Trust Badges Link ---- */
.booking-trust a {
    color: var(--booking-gold);
    text-decoration: none;
}

.booking-trust a:hover {
    text-decoration: underline;
}

/* ---- Section Title Gold ---- */
.booking-section-title--gold {
    color: var(--booking-gold);
    margin-bottom: 0.875rem;
}

/* ---- Readonly Input Display ---- */
.booking-input--readonly {
    background: #fff;
}

/* ---- Toggle Group (flex:1 button pair) ---- */
.booking-toggle-group {
    display: flex;
    gap: 0.5rem;
}

.booking-toggle-group .booking-btn {
    flex: 1;
    padding: 0.6rem;
}

/* ---- Section Block (padding + margin wrapper) ---- */
.booking-section-block {
    padding: 1rem;
    margin-bottom: 1.5rem;
}

.booking-section-block--flush {
    margin-bottom: 1rem;
}

/* ---- Checkbox Component ---- */
.booking-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
}

.booking-checkbox {
    margin-top: 0.2rem;
    accent-color: var(--booking-gold);
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* ---- Checkbox Description ---- */
.booking-checkbox-title {
    font-size: 0.9rem;
    font-weight: 700;
}

.booking-checkbox-desc {
    font-size: 0.8rem;
    color: var(--booking-text-muted);
    margin-top: 0.2rem;
}

/* ---- CGV Checkbox Text ---- */
.booking-cgv__text {
    font-size: 0.85rem;
    color: var(--booking-text-secondary);
}

/* ---- Hint Variants ---- */
.booking-hint--block {
    display: block;
    margin-left: 0;
    margin-top: 0.25rem;
}

.booking-hint--xs {
    font-size: 0.7rem;
}

.booking-hint--flush {
    margin-left: 0;
}

/* ---- Navigation Flush (no top border for first step) ---- */
.booking-nav--flush {
    border-top: none;
    padding-top: 0;
    margin-top: 0;
}

/* ---- Info Block Lists ---- */
.booking-info ul,
.booking-info ol {
    padding-left: 1.25rem;
    margin-bottom: 0;
}

.booking-info .booking-info__note {
    font-size: 0.75rem;
    margin-bottom: 0;
    margin-top: 0.5rem;
}

/* ---- Policy List (small text) ---- */
.booking-policy-list {
    padding-left: 1.25rem;
    font-size: 0.8rem;
    margin-bottom: 0;
}

/* ---- Link Size Small ---- */
.booking-link--sm {
    font-size: 0.8rem;
}

/* ---- Auth CTA Block (login/register buttons in step-5) ---- */
.booking-auth-cta {
    padding: 1.25rem;
}

.booking-auth-cta__desc {
    font-size: 0.9rem;
    color: var(--booking-text-secondary);
}

.booking-auth-cta__buttons {
    display: flex;
    gap: 0.5rem;
}

.booking-auth-cta__buttons .booking-btn {
    flex: 1;
    text-align: center;
}

/* ---- Confirmation Info Block (left-aligned, spaced) ---- */
.booking-confirmation .booking-info {
    text-align: left;
    margin-bottom: 1.5rem;
}

/* ---- Link Bold ---- */
.booking-link--bold {
    font-weight: 700;
}

/* ---- Price Accent Small (inline options pricing) ---- */
.booking-price-accent--sm {
    font-size: 0.85rem;
    font-weight: 500;
}

/* ===========================================
 * UX PHASE 4 — Micro-interactions & Polish
 * =========================================== */

/* ---- Textarea ---- */
.booking-textarea {
    resize: vertical;
    min-height: 100px;
}

/* ---- Select fix (iOS zoom prevention) ---- */
select.booking-input {
    font-size: 1.05rem; /* ≥16px prevents iOS Safari auto-zoom on focus */
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23555' viewBox='0 0 16 16'%3e%3cpath d='M1.5 5.5l6.5 6.5 6.5-6.5'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 0.875rem center;
    background-size: 14px;
    padding-right: 2.75rem;
}

/* ---- Character Counter ---- */
.booking-char-counter {
    font-size: 0.7rem;
    color: var(--booking-text-muted);
    white-space: nowrap;
    flex-shrink: 0;
    padding-left: 0.5rem;
    transition: color 0.2s;
}

.booking-char-counter--warn {
    color: #f59e0b;
    font-weight: 600;
}

/* ---- Counter Value Bump Animation ---- */
@keyframes booking-counter-bump {
    0% { transform: scale(1); }
    50% { transform: scale(1.2); }
    100% { transform: scale(1); }
}

.booking-counter__value--bump {
    animation: booking-counter-bump 0.2s ease;
}

/* ---- Vehicle Card Hover Lift ---- */
.vehicle-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.vehicle-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--booking-shadow-hover);
}

.vehicle-card--selected {
    transform: translateY(-2px);
}

/* ---- Button Press Effect ---- */
.booking-btn:active:not(:disabled) {
    transform: scale(0.97);
}

/* ---- Progress Step Pulse on Active ---- */
@keyframes booking-pulse-gold {
    0%, 100% { box-shadow: 0 0 0 0 rgba(171, 125, 63, 0.4); }
    50% { box-shadow: 0 0 0 6px rgba(171, 125, 63, 0); }
}

.booking-progress__circle--active {
    animation: booking-pulse-gold 2s ease infinite;
}

/* ---- Price Animate on Change ---- */
@keyframes booking-price-flash {
    0% { color: var(--booking-gold-light); }
    100% { color: var(--booking-gold); }
}

.booking-summary__row--total .booking-summary__value {
    transition: color 0.3s ease;
}

/* ---- Smooth Scroll for Step Transitions ---- */
.booking-main {
    scroll-behavior: smooth;
}

/* ---- Alert Dismiss Animation ---- */
.booking-alert[x-transition] {
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.booking-alert[x-transition\:enter] {
    opacity: 0;
    transform: translateY(-4px);
}

/* ---- Tooltip Arrow ---- */
.booking-tooltip::before {
    content: '';
    position: absolute;
    bottom: calc(100% + 2px);
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--booking-dark);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s;
}

.booking-tooltip:hover::before,
.booking-tooltip:focus::before {
    opacity: 1;
}

/* ---- Input Placeholder (readable for all ages) ---- */
.booking-input::placeholder {
    color: #8a8278; /* warm muted — WCAG AA on white */
    opacity: 1;
    font-weight: 400;
    transition: opacity 0.2s;
}

.booking-input:focus::placeholder {
    opacity: 0.5;
}

/* ---- Uppercase Helper ---- */
.text-uppercase {
    text-transform: uppercase;
}

/* ---- Section Title No Bottom Margin ---- */
.booking-section-title.mb-0 {
    margin-bottom: 0;
}

/* ==================================================
   ACCOUNT PAGES
   ================================================== */

/* ---- Account Navigation ---- */
.booking-account-nav {
    background: #fff;
    border-bottom: 1px solid var(--booking-border);
    position: sticky;
    top: 0;
    z-index: 100;
}

.booking-account-nav__items {
    display: flex;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.booking-account-nav__items::-webkit-scrollbar { display: none; }

.booking-account-nav__item {
    padding: 0.875rem 1.25rem;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--booking-text-secondary);
    text-decoration: none;
    white-space: nowrap;
    border: none;
    border-bottom: 2.5px solid transparent;
    background: none;
    cursor: pointer;
    transition: all 0.2s;
    min-height: 48px;
    display: flex;
    align-items: center;
}

.booking-account-nav__item:hover { color: var(--booking-gold); }

.booking-account-nav__item--active {
    color: var(--booking-gold);
    border-bottom-color: var(--booking-gold);
}

.booking-account-nav__item--logout {
    color: var(--booking-text-muted);
    margin-left: auto;
    font-size: 0.8rem;
}

.booking-account-nav__item--logout:hover { color: #dc3545; }

/* ---- Account Type Badges ---- */
.booking-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.75rem;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.booking-badge--standard { background: var(--booking-gold-subtle); color: var(--booking-gold); }
.booking-badge--concierge { background: #e8e0f0; color: #6a3d9a; }
.booking-badge--partner { background: #d4edda; color: #155724; }
.booking-badge--company { background: #cce5ff; color: #004085; }
.booking-badge--gold { background: var(--booking-gold-subtle, #f5eedd); color: var(--booking-gold, #ab7d3f); font-weight: 600; }

/* ---- Modal text ---- */
.booking-modal__text {
    font-size: 0.95rem;
    color: var(--booking-text-secondary);
    margin-bottom: 1.25rem;
    line-height: 1.6;
}

/* ---- Trip Type Badge ---- */
.booking-trip-type {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: 4px;
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
}

.booking-trip-type--simple { background: #f0f0f0; color: #555; }
.booking-trip-type--aller_retour { background: #fff3cd; color: #856404; }
.booking-trip-type--disposition { background: #cce5ff; color: #004085; }

/* ---- Quick Stats ---- */
.booking-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.booking-stat {
    background: var(--booking-card-bg);
    border: 1px solid var(--booking-border);
    border-radius: var(--booking-radius-sm);
    padding: 0.75rem;
    text-align: center;
    transition: var(--booking-transition);
}

.booking-stat:hover {
    border-color: var(--booking-gold-border);
    box-shadow: var(--booking-shadow);
}

.booking-stat__value {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--booking-gold);
    line-height: 1;
}

.booking-stat__label {
    font-size: 0.7rem;
    color: var(--booking-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 0.25rem;
}

/* ---- Passenger Card ---- */
.booking-passenger-card {
    background: var(--booking-card-bg);
    border: 1px solid var(--booking-border);
    border-radius: var(--booking-radius);
    padding: 1rem;
    transition: all 0.2s ease;
    margin-bottom: 0.75rem;
}

.booking-passenger-card:hover {
    box-shadow: var(--booking-shadow-hover);
    border-color: var(--booking-gold-border);
    transform: translateY(-1px);
}

.booking-passenger-card__name { font-weight: 700; font-size: 0.95rem; }
.booking-passenger-card__meta { font-size: 0.8rem; color: var(--booking-text-secondary); margin-top: 0.25rem; }

.booking-passenger-card__actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

.booking-passenger-card--self {
    border-color: var(--booking-gold-border);
    background: var(--booking-gold-subtle);
}

/* ---- Invoice Table ---- */
.booking-invoice-table { width: 100%; font-size: 0.85rem; border-collapse: collapse; }

.booking-invoice-table th {
    padding: 0.75rem;
    border-bottom: 2px solid var(--booking-border);
    font-weight: 700;
    font-size: 0.75rem;
    text-transform: uppercase;
    color: var(--booking-text-muted);
    text-align: left;
}

.booking-invoice-table td {
    padding: 0.75rem;
    border-bottom: 1px solid var(--booking-border-light);
    vertical-align: middle;
}

.booking-invoice-table tr { transition: background 0.15s ease; }
.booking-invoice-table tr:hover td { background: var(--booking-gold-subtle); }

@media (max-width: 768px) {
    .booking-invoice-table thead { display: none; }
    .booking-invoice-table tr { display: block; padding: 0.75rem 0; border-bottom: 1px solid var(--booking-border); }
    .booking-invoice-table td { display: flex; justify-content: space-between; padding: 0.3rem 0; border: none; }
    .booking-invoice-table td::before { content: attr(data-label); font-weight: 600; color: var(--booking-text-muted); font-size: 0.75rem; }
}

/* ---- Dashboard Search & Filters ---- */

/* Search section: bar + filter toggle */
.dash-search-section {
    display: flex;
    gap: 0.75rem;
    align-items: stretch;
}

.dash-search {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
}

.dash-search__icon {
    position: absolute;
    left: 0.875rem;
    color: var(--booking-text-muted, #6b6b6b);
    pointer-events: none;
    flex-shrink: 0;
}

.dash-search__input {
    width: 100%;
    padding: 0.65rem 2.25rem 0.65rem 2.75rem;
    border: 2px solid var(--booking-border, #e5e5e5);
    border-radius: 10px;
    font-size: 0.88rem;
    background: var(--booking-card-bg, #fff);
    transition: border-color 0.2s, box-shadow 0.2s;
    outline: none;
}

.dash-search__input:focus {
    border-color: var(--booking-gold, #ab7d3f);
    box-shadow: 0 0 0 3px rgba(171, 125, 63, 0.12);
}

.dash-search__input::placeholder {
    color: var(--booking-text-muted, #6b6b6b);
    font-size: 0.85rem;
}

.dash-search__clear {
    position: absolute;
    right: 0.5rem;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--booking-text-muted, #6b6b6b);
    padding: 0.25rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    transition: color 0.2s;
}

.dash-search__clear:hover {
    color: var(--booking-text, #333);
}

/* Filter toggle button */
.dash-filter-toggle {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.65rem 1rem;
    border: 2px solid var(--booking-border, #e5e5e5);
    border-radius: 10px;
    background: var(--booking-card-bg, #fff);
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 600;
    color: #666;
    white-space: nowrap;
    transition: all 0.2s;
    position: relative;
}

.dash-filter-toggle:hover {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
}

.dash-filter-toggle--active {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #fdf8f0);
}

.dash-filter-toggle__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    border-radius: 9px;
    background: var(--booking-gold, #ab7d3f);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    line-height: 1;
}

/* Advanced filters panel */
.dash-filters {
    background: var(--booking-card-bg, #fff);
    border: 1px solid var(--booking-border, #e5e5e5);
    border-radius: 12px;
    padding: 1.25rem;
    margin-bottom: 1rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.dash-filters__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}

.dash-filters__group {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.dash-filters__label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--booking-text-muted, #6b6b6b);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.dash-filters__date-range {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.dash-filters__date-sep {
    color: var(--booking-text-muted, #6b6b6b);
    font-size: 0.85rem;
}

.dash-filters__date,
.dash-filters__select {
    padding: 0.45rem 0.65rem;
    border: 1.5px solid var(--booking-border, #e5e5e5);
    border-radius: 8px;
    font-size: 0.85rem;
    background: #fff;
    width: 100%;
    transition: border-color 0.2s;
    outline: none;
}

.dash-filters__date:focus,
.dash-filters__select:focus {
    border-color: var(--booking-gold, #ab7d3f);
}

.dash-filters__actions {
    margin-top: 1rem;
    text-align: right;
}

.dash-filters__clear {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--booking-gold, #ab7d3f);
    padding: 0.4rem 0;
}

.dash-filters__clear:hover {
    text-decoration: underline;
}

/* Filter tags (shown when panel is closed but filters active) */
.dash-filter-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    align-items: center;
}

.dash-filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.3rem 0.65rem;
    border-radius: 20px;
    font-size: 0.78rem;
    background: var(--booking-gold-subtle, #fdf8f0);
    color: var(--booking-gold, #ab7d3f);
    border: 1px solid var(--booking-gold-border, #e8d5b8);
}

.dash-filter-tag button {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    color: var(--booking-gold, #ab7d3f);
    padding: 0;
    margin-left: 0.15rem;
}

.dash-filter-tag button:hover {
    color: #000;
}

.dash-filter-tag--clear {
    background: transparent;
    border: 1px dashed var(--booking-gold-border, #e8d5b8);
    cursor: pointer;
    font-weight: 600;
}

.dash-filter-tag--clear:hover {
    background: var(--booking-gold-subtle, #fdf8f0);
}

/* Date quick-pick buttons */
.dash-filters__date-picks {
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.dash-date-pick {
    padding: 0.3rem 0.65rem;
    border: 1.5px solid var(--booking-border, #e5e5e5);
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    background: #fff;
    color: var(--booking-text-secondary, #3a3a3a);
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.dash-date-pick:hover {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
}

.dash-date-pick--active {
    background: var(--booking-gold, #ab7d3f);
    border-color: var(--booking-gold, #ab7d3f);
    color: #fff;
}

/* Spending analytics bar */
.dash-spending {
    display: flex;
    align-items: center;
    background: linear-gradient(135deg, rgba(171,125,63,0.06), rgba(171,125,63,0.02));
    border: 1px solid var(--booking-gold-border, rgba(171,125,63,0.20));
    border-radius: var(--booking-radius, 10px);
    padding: 0.75rem 1rem;
    gap: 1rem;
}

.dash-spending__item {
    flex: 1;
    text-align: center;
    min-width: 0;
}

.dash-spending__value {
    display: block;
    font-size: 1rem;
    font-weight: 800;
    color: var(--booking-gold, #ab7d3f);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dash-spending__label {
    display: block;
    font-size: 0.65rem;
    color: var(--booking-text-muted, #6b6b6b);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-top: 0.1rem;
}

.dash-spending__sep {
    width: 1px;
    height: 28px;
    background: var(--booking-gold-border, rgba(171,125,63,0.25));
    flex-shrink: 0;
}

/* Re-book link on order cards */
.dash-rebook-link {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--booking-text-muted, #6b6b6b);
    cursor: pointer;
    padding: 2px 8px;
    border-radius: 4px;
    transition: all 0.15s;
    white-space: nowrap;
}

.dash-rebook-link:hover {
    color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #fdf8f0);
}

/* Mobile responsive */
@media (max-width: 768px) {
    .dash-search-section {
        flex-direction: column;
    }
    .dash-filter-toggle {
        align-self: flex-start;
    }
    .dash-filters__grid {
        grid-template-columns: 1fr;
    }
    .dash-filters__date-range {
        flex-direction: row;
    }
    .dash-filters__date {
        flex: 1;
        min-width: 0;
    }
    .dash-spending {
        gap: 0.5rem;
        padding: 0.6rem 0.75rem;
    }
    .dash-spending__value {
        font-size: 0.85rem;
    }
    .dash-spending__label {
        font-size: 0.6rem;
    }
}

/* ---- Dashboard Status Tabs ---- */
.dash-nav { display: flex; gap: 0.5rem; margin-bottom: 1.5rem; overflow-x: auto; }

.dash-nav__item {
    padding: 0.5rem 1.25rem;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
    border: 2px solid var(--booking-border, #e5e5e5);
    background: #fff;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s;
    text-decoration: none;
    color: #666;
}

.dash-nav__item:hover { border-color: var(--booking-gold, #ab7d3f); color: var(--booking-gold, #ab7d3f); }
.dash-nav__item--active { background: var(--booking-gold, #ab7d3f); color: #fff; border-color: var(--booking-gold, #ab7d3f); }

.order-card {
    background: #fff;
    border: 1px solid var(--booking-border);
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    padding: 1.25rem;
    margin-bottom: 1rem;
    transition: all 0.2s ease;
}

.order-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
    border-color: var(--booking-gold-border);
    transform: translateY(-1px);
}

.order-status {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
}

.order-status--pending { background: #fff3cd; color: #856404; }
.order-status--validated { background: #d4edda; color: #155724; }
.order-status--active { background: #cce5ff; color: #004085; }
.order-status--completed { background: #e2e3e5; color: #383d41; }
.order-status--cancelled { background: #f8d7da; color: #842029; }

/* ---- Timeline (migrated from inline) ---- */
.timeline { position: relative; padding-left: 2rem; }
.timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: #e5e5e5; }

.timeline__item { position: relative; padding-bottom: 1.25rem; font-size: 0.85rem; }

.timeline__dot {
    position: absolute; left: -2rem; top: 2px; width: 18px; height: 18px;
    border-radius: 50%; background: #e5e5e5; display: flex; align-items: center;
    justify-content: center; font-size: 0.6rem; z-index: 1;
}

.timeline__item--done .timeline__dot { background: #28a745; color: #fff; }
.timeline__item--active .timeline__dot { background: var(--booking-gold, #ab7d3f); color: #fff; box-shadow: 0 0 0 3px rgba(171,125,63,0.2); }

/* ==================================================
   PREMIUM ACCOUNT UX ENHANCEMENTS
   ================================================== */

/* ---- Back Link ---- */
.booking-back-link {
    display: inline-block;
    margin-bottom: 1rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--booking-gold);
    text-decoration: none;
    transition: var(--booking-transition);
}

.booking-back-link:hover {
    color: var(--booking-gold-light);
    transform: translateX(-2px);
}

/* ---- Avatar (circle with initials) ---- */
.booking-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.95rem;
    flex-shrink: 0;
    letter-spacing: 0.5px;
    transition: var(--booking-transition);
}

.booking-avatar--gold {
    background: var(--booking-gold);
    color: #fff;
}

.booking-avatar--muted {
    background: var(--booking-border);
    color: var(--booking-text-secondary);
}

.booking-avatar--sm {
    width: 32px;
    height: 32px;
    font-size: 0.75rem;
}

.booking-avatar--lg {
    width: 80px;
    height: 80px;
    font-size: 1.6rem;
}

.booking-avatar--logo {
    border-radius: 12px;
}

.booking-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
}

/* ---- Avatar Upload ---- */
.avatar-upload {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding: 1.25rem;
    border: 2px dashed var(--booking-border);
    border-radius: 12px;
    transition: var(--booking-transition);
    margin-bottom: 1.5rem;
}

.avatar-upload:hover {
    border-color: var(--booking-gold);
}

.avatar-upload__preview {
    position: relative;
    flex-shrink: 0;
}

.avatar-upload__preview .booking-avatar {
    cursor: pointer;
}

.avatar-upload__preview .avatar-upload__remove {
    position: absolute;
    top: -6px;
    right: -6px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #dc3545;
    color: #fff;
    border: 2px solid #fff;
    font-size: 0.65rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    line-height: 1;
    padding: 0;
}

.avatar-upload__info {
    flex: 1;
    min-width: 0;
}

.avatar-upload__title {
    font-weight: 700;
    font-size: 0.95rem;
    margin-bottom: 0.2rem;
}

.avatar-upload__desc {
    font-size: 0.8rem;
    color: var(--booking-text-muted);
    margin-bottom: 0.5rem;
}

.avatar-upload__btn {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--booking-gold);
    background: none;
    border: 1px solid var(--booking-gold);
    padding: 0.35rem 0.9rem;
    border-radius: 6px;
    cursor: pointer;
    transition: var(--booking-transition);
}

.avatar-upload__btn:hover {
    background: var(--booking-gold);
    color: #fff;
}

.avatar-upload__btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* ---- Header User Area ---- */
.booking-header__user {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
    color: #fff;
}

.booking-header__user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--booking-gold);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.75rem;
    letter-spacing: 0.5px;
}

.booking-header__user-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: rgba(255,255,255,0.9);
}

@media (max-width: 576px) {
    .booking-header__user-name { display: none; }
}

/* ---- Greeting (dashboard) ---- */
.booking-greeting {
    font-size: 1.1rem;
    font-weight: 500;
    color: var(--booking-text-secondary);
    margin-bottom: 0.25rem;
}

.booking-greeting strong {
    color: var(--booking-text);
    font-weight: 700;
}

/* ---- Spinner Size Variants ---- */
.booking-spinner--lg {
    width: 40px;
    height: 40px;
    border-width: 3px;
    border-color: rgba(171,125,63,0.2);
    border-top-color: var(--booking-gold);
}

/* ---- Button Variants ---- */
.booking-btn--sm {
    padding: 0.35rem 0.875rem;
    font-size: 0.8rem;
}

.booking-btn--danger {
    background: #dc3545;
    color: #fff;
    border: none;
    border-radius: var(--booking-radius-sm);
}

.booking-btn--danger:hover {
    background: #c82333;
}

.booking-btn--danger-outline {
    background: none;
    border: 1px solid #dc3545;
    color: #dc3545;
    border-radius: var(--booking-radius-sm);
}

.booking-btn--danger-outline:hover {
    background: #dc3545;
    color: #fff;
}

.booking-btn--ghost {
    background: none;
    border: none;
    color: var(--booking-gold);
    font-size: 0.85rem;
    cursor: pointer;
    padding: 0.25rem 0.5rem;
    transition: var(--booking-transition);
}

.booking-btn--ghost:hover {
    color: var(--booking-gold-light);
}

/* ---- Danger Card ---- */
.booking-card--danger {
    border: 2px solid #dc3545;
}

.booking-card--warning {
    border-color: #ffc107;
}

/* ---- OTP Input ---- */
.booking-input--otp {
    text-align: center;
    font-size: 1.75rem;
    letter-spacing: 0.6rem;
    font-weight: 700;
    padding: 0.75rem 1rem;
    font-family: 'Inter', monospace;
}

/* ---- Page Title (used across account pages) ---- */
.booking-page-title {
    font-size: 1.5rem;
    font-weight: 800;
    margin: 0;
}

.booking-page-subtitle {
    color: var(--booking-text-muted);
    font-size: 0.9rem;
    margin: 0;
}

/* ---- Loading Container (with aria-live) ---- */
.booking-loading {
    text-align: center;
    padding: 2.5rem 0;
}

.booking-loading__text {
    color: var(--booking-text-muted);
    margin-top: 1rem;
    font-size: 0.9rem;
}

/* ---- Error Box ---- */
.booking-error-box {
    background: linear-gradient(135deg, #fef2f2 0%, #fff5f5 50%, #fefce8 100%);
    border: 1px solid #fecaca;
    border-radius: var(--booking-radius);
    padding: 2.5rem 1.5rem;
    text-align: center;
    animation: booking-alert-in 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.booking-error-box::before {
    content: '😕';
    display: block;
    font-size: 2.5rem;
    margin-bottom: 0.75rem;
    line-height: 1;
}

.booking-error-box__message {
    color: #7f1d1d;
    font-weight: 600;
    font-size: 0.95rem;
    margin-bottom: 0.35rem;
}

.booking-error-box__hint {
    color: #991b1b;
    font-size: 0.82rem;
    opacity: 0.7;
    margin-bottom: 1rem;
}

/* ---- Empty State ---- */
.booking-empty {
    text-align: center;
    padding: 2.5rem 0;
}

.booking-empty__icon {
    font-size: 3rem;
    color: var(--booking-border);
    margin-bottom: 1rem;
    line-height: 1;
}

.booking-empty__title {
    font-weight: 700;
    margin-bottom: 0.5rem;
}

.booking-empty__text {
    color: var(--booking-text-secondary);
    margin-bottom: 1.5rem;
}

/* ---- Toggle Group (civilité, account type) ---- */
.booking-toggle-group {
    display: flex;
    gap: 0.5rem;
}

.booking-toggle-group--fill .booking-btn {
    flex: 1;
}

/* ---- Resend Countdown ---- */
.booking-countdown {
    font-size: 0.8rem;
    color: var(--booking-text-muted);
    text-align: center;
    margin-top: 0.5rem;
}

.booking-countdown strong {
    color: var(--booking-gold);
    font-weight: 700;
}

/* ---- Trust Signal ---- */
.booking-trust {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    font-size: 0.8rem;
    color: var(--booking-text-muted);
    margin-bottom: 1rem;
}

.booking-trust__star {
    color: var(--booking-gold);
    font-weight: 700;
}

/* ---- Cancel Confirmation ---- */
.booking-cancel__title {
    font-size: 1rem;
    font-weight: 700;
    color: #842029;
    margin-bottom: 0.75rem;
}

/* ---- Smooth page entry ---- */
@keyframes booking-fade-up {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.booking-fade-up {
    animation: booking-fade-up 0.3s ease-out;
}

/* ---- Responsive padding adjustments ---- */
@media (max-width: 576px) {
    .booking-account-nav__item {
        padding: 0.75rem 0.875rem;
        font-size: 0.8rem;
    }

    .booking-stats {
        grid-template-columns: repeat(2, 1fr);
    }

    .booking-stat__value {
        font-size: 1.25rem;
    }

    .booking-page-title {
        font-size: 1.25rem;
    }
}

/* ---- Dark Scheme Support ---- */
@media (prefers-color-scheme: dark) {
    /* Prepare tokens for future dark mode toggle */
    .booking-page[data-theme="dark"] {
        --booking-bg: #111;
        --booking-card-bg: #1e1e1e;
        --booking-border: #333;
        --booking-border-light: #2a2a2a;
        --booking-text: #f0f0f0;
        --booking-text-secondary: #b0b0b0;
        --booking-text-muted: #777;
        --booking-gold-subtle: rgba(171, 125, 63, 0.1);
        --booking-shadow: 0 1px 3px rgba(0,0,0,0.3);
        --booking-shadow-hover: 0 4px 12px rgba(0,0,0,0.4);
    }
}

/* ==================================================
   V2 — 3-STEP BOOKING FLOW STYLES
   ================================================== */

/* ---- Pill-Tab Progress Bar ---- */
.booking-pills-wrap {
    margin-bottom: 0.5rem;
}

.booking-pills {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
}

.booking-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.55rem 1.35rem;
    border-radius: 24px;
    font-size: 0.85rem;
    font-weight: 600;
    border: 1.5px solid #e5e5e5;
    background: #f7f7f7;
    color: var(--booking-text-muted, #6b6b6b);
    cursor: default;
    transition: all 0.25s ease;
    user-select: none;
    white-space: nowrap;
}

.booking-pill--active {
    background: var(--booking-gold, #ab7d3f);
    color: #fff;
    border-color: var(--booking-gold, #ab7d3f);
    box-shadow: 0 2px 8px rgba(171, 125, 63, 0.3);
}

.booking-pill--done {
    background: var(--booking-gold-subtle, #f5eedd);
    color: var(--booking-gold, #ab7d3f);
    border-color: var(--booking-gold-border, #e5d5b8);
}

.booking-pill--upcoming {
    background: #f7f7f7;
    color: var(--booking-text-muted, #6b6b6b);
    border-color: #e5e5e5;
}

.booking-pill--clickable {
    cursor: pointer;
}

.booking-pill--clickable:hover {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
    transform: translateY(-1px);
    transition: all 0.2s ease;
}

.booking-pill__num {
    font-weight: 700;
    font-size: 0.8rem;
}

.booking-pill__dot {
    font-weight: 900;
    font-size: 1rem;
    line-height: 1;
    opacity: 0.6;
}

.booking-pill__label {
    font-weight: 600;
}

.booking-pill__check {
    flex-shrink: 0;
    margin-left: -0.1rem;
}

/* Pill mobile compact */
.booking-pills-mobile {
    display: none;
    align-items: center;
    gap: 0.5rem;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--booking-text-secondary, #666);
}

.booking-pills-mobile__step {
    font-weight: 700;
    color: var(--booking-gold, #ab7d3f);
}

.booking-pills-mobile__dots {
    display: flex;
    gap: 0.35rem;
    margin-left: 0.5rem;
}

.booking-pills-mobile__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #e5e5e5;
    transition: all 0.25s ease;
}

.booking-pills-mobile__dot--active {
    background: var(--booking-gold, #ab7d3f);
    box-shadow: 0 0 0 3px rgba(171, 125, 63, 0.2);
}

.booking-pills-mobile__dot--done {
    background: var(--booking-gold-border, #e5d5b8);
}

@media (max-width: 576px) {
    .booking-pills { display: none; }
    .booking-pills-mobile { display: flex; }
}

@media (min-width: 577px) and (max-width: 768px) {
    .booking-pill {
        padding: 0.45rem 0.9rem;
        font-size: 0.78rem;
    }
}

/* ---- Route Badges ---- */
.route-badges {
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
    margin-bottom: 0.75rem;
}

.route-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.85rem;
    border-radius: 8px;
    background: var(--booking-gold-subtle, #f5eedd);
    color: var(--booking-gold, #ab7d3f);
    font-size: 0.82rem;
    font-weight: 600;
    white-space: nowrap;
}

.route-badge svg {
    flex-shrink: 0;
    opacity: 0.7;
}

.route-badge--return {
    background: #fff3cd;
    color: #856404;
}

/* ---- Vehicle Grid Inline (Step 1) ---- */
.vehicle-grid--inline {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0.75rem;
}

.vehicle-card--compact {
    padding: 0.875rem;
    position: relative;
}

.vehicle-card--compact .vehicle-card__name {
    font-size: 0.9rem;
    margin-bottom: 0.25rem;
}

.vehicle-card--compact .vehicle-card__specs {
    font-size: 0.75rem;
    margin-bottom: 0.5rem;
}

.vehicle-card--compact .vehicle-card__price {
    font-size: 1.1rem;
}

.vehicle-card--compact .vehicle-card__price small {
    font-size: 0.65rem;
}

.vehicle-card--compact .vehicle-card__badge {
    font-size: 0.6rem;
    padding: 0.15rem 0.45rem;
}

.vehicle-card--compact .vehicle-card__check {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--booking-gold, #ab7d3f);
    display: flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 576px) {
    .vehicle-grid--inline {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.5rem;
    }

    .vehicle-card--compact {
        padding: 0.65rem;
    }

    .vehicle-card--compact .vehicle-card__name {
        font-size: 0.8rem;
    }
}

/* ---- Comfort Card (collapsible sections in step 2) ---- */
.booking-comfort-card {
    border: 1px solid var(--booking-border, #e5e5e5);
    border-radius: 10px;
    padding: 1rem 1.25rem;
    background: var(--booking-card-bg, #fff);
    transition: border-color 0.2s ease;
}

.booking-comfort-card:hover {
    border-color: var(--booking-gold-border, #e5d5b8);
}

.booking-comfort-card__title {
    font-weight: 700;
    font-size: 0.9rem;
    margin-bottom: 0.75rem;
    color: var(--booking-text, #1a1a1a);
}
.booking-comfort-card__title--icon {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* ---- Section Icon (gold circle for section headers) ---- */
.booking-section-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: var(--booking-gold-subtle, #faf4e8);
    color: var(--booking-gold, #ab7d3f);
    flex-shrink: 0;
}
.booking-section-icon svg {
    width: 16px;
    height: 16px;
}
.booking-section-icon--sm {
    width: 26px;
    height: 26px;
    border-radius: 6px;
}
.booking-section-icon--sm svg {
    width: 14px;
    height: 14px;
}

/* ---- Recap strip (passengers/luggage/vehicle) ---- */
.booking-recap-strip {
    display: flex;
    gap: 0;
    border: 1px solid var(--booking-border-light, #eee);
    border-radius: var(--booking-radius, 10px);
    overflow: hidden;
    background: var(--booking-card-bg, #fff);
}
.booking-recap-strip__item {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.65rem 0.75rem;
    min-width: 0;
}
.booking-recap-strip__item + .booking-recap-strip__item {
    border-left: 1px solid var(--booking-border-light, #eee);
}
.booking-recap-strip__icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: var(--booking-gold-subtle, #faf4e8);
    color: var(--booking-gold, #ab7d3f);
    flex-shrink: 0;
}
.booking-recap-strip__icon svg {
    width: 16px;
    height: 16px;
}
.booking-recap-strip__value {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--booking-text, #333);
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.booking-recap-strip__label {
    font-size: 0.68rem;
    color: var(--booking-text-muted, #999);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    line-height: 1.2;
}
@media (max-width: 575px) {
    .booking-recap-strip { flex-direction: column; }
    .booking-recap-strip__item + .booking-recap-strip__item {
        border-left: none;
        border-top: 1px solid var(--booking-border-light, #eee);
    }
    .booking-recap-strip__item { padding: 0.5rem 0.75rem; }
}

/* ---- Service option rows (premium design) ---- */
.booking-service-list {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.booking-service-row {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.75rem 0.85rem;
    border: 1.5px solid var(--booking-border, #e0dbd4);
    border-radius: 10px;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
    -webkit-tap-highlight-color: transparent;
}
.booking-service-row + .booking-service-row {
    margin-top: 0.4rem;
}
.booking-service-row:hover {
    border-color: var(--booking-gold-border, #e5d5b8);
    background: rgba(171,125,63,0.02);
}
.booking-service-row--active {
    border-color: var(--booking-gold, #ab7d3f);
    background: linear-gradient(135deg, #fefcf8 0%, #fdf8f0 100%);
    box-shadow: 0 2px 8px rgba(171,125,63,0.08);
}
.booking-service-row__info {
    flex: 1;
    min-width: 0;
}
.booking-service-row__name {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--booking-text, #333);
}
.booking-service-row__desc {
    font-size: 0.72rem;
    color: var(--booking-text-muted, #999);
    line-height: 1.3;
    margin-top: 0.1rem;
}
.booking-service-row__price {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--booking-gold, #ab7d3f);
    white-space: nowrap;
}

/* ---- Comment suggestion chips ---- */
.booking-chip-suggest {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.6rem;
    border-radius: 14px;
    font-size: 0.72rem;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid var(--booking-border, #ddd);
    background: var(--booking-card-bg, #fff);
    color: var(--booking-text-muted, #888);
    transition: all 0.15s;
    touch-action: manipulation;
}
.booking-chip-suggest:hover {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #faf4e8);
}

/* ---- Vehicle card (bottom of step 2) ---- */
.booking-vehicle-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem;
    border: 1.5px solid var(--booking-gold-border, #e5d5b8);
    border-radius: var(--booking-radius, 10px);
    background: var(--booking-gold-subtle, #faf6f0);
}
.booking-vehicle-card__left {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}
.booking-vehicle-card__icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(171,125,63,0.12);
    color: var(--booking-gold, #ab7d3f);
    flex-shrink: 0;
}
.booking-vehicle-card__icon svg {
    width: 22px;
    height: 22px;
}
.booking-vehicle-card__name {
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--booking-text, #333);
}
.booking-vehicle-card__change {
    font-size: 0.72rem;
    color: var(--booking-gold, #ab7d3f);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    font-weight: 500;
    text-decoration: none;
}
.booking-vehicle-card__change:hover {
    text-decoration: underline;
}
.booking-vehicle-card__price {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--booking-gold, #ab7d3f);
    white-space: nowrap;
}

/* ---- Add-on Pill Buttons (Ajouter enfants / Ajouter animaux) ---- */
.booking-addon-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 1rem;
    border-radius: 20px;
    border: 1.5px solid #e5e5e5;
    background: #fff;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    color: var(--booking-text-secondary, #666);
    transition: all 0.2s ease;
    white-space: nowrap;
}

.booking-addon-pill:hover {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
}

.booking-addon-pill--active {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #f5eedd);
}

.booking-addon-pill svg {
    flex-shrink: 0;
    opacity: 0.7;
}

/* ════════════════════════════════════════════════════════════
   Animal Card Grid — premium visual selector
════════════════════════════════════════════════════════════ */

.booking-comfort-card--animal {
    background: linear-gradient(135deg, #fffdf9 0%, #fff 100%);
}

.booking-animal-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.65rem;
}
@media (max-width: 320px) {
    .booking-animal-grid { grid-template-columns: 1fr 1fr; }
}

.booking-animal-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    padding: 0.9rem 0.5rem 0.75rem;
    border: 2px solid var(--booking-border, #e5e5e5);
    border-radius: 12px;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease, background 0.2s ease;
    touch-action: manipulation;
    text-align: center;
    min-height: 100px;
    color: var(--booking-text-secondary, #555);
}
.booking-animal-card:hover {
    border-color: var(--booking-gold-border, #e5d5b8);
    box-shadow: 0 3px 12px rgba(171,125,63,0.12);
    transform: translateY(-2px);
}
.booking-animal-card--active {
    border-color: var(--booking-gold, #ab7d3f);
    background: linear-gradient(135deg, #fdf9f2 0%, #faf4e8 100%);
    box-shadow: 0 4px 16px rgba(171,125,63,0.18);
    color: var(--booking-gold, #ab7d3f);
    transform: translateY(-2px);
}
@keyframes booking-animal-select {
    0%   { transform: translateY(-2px) scale(1); }
    40%  { transform: translateY(-2px) scale(1.04); }
    100% { transform: translateY(-2px) scale(1); }
}
.booking-animal-card--active {
    animation: booking-animal-select 0.25s ease;
}
.booking-animal-card__check {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--booking-gold, #ab7d3f);
    display: flex;
    align-items: center;
    justify-content: center;
}
.booking-animal-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--booking-gold-subtle, #faf4e8);
    transition: background 0.2s ease;
    color: var(--booking-gold, #ab7d3f);
    margin-bottom: 0.1rem;
}
.booking-animal-card--active .booking-animal-card__icon {
    background: rgba(171,125,63,0.18);
}
.booking-animal-card__name {
    font-size: 0.8rem;
    font-weight: 700;
    color: inherit;
    line-height: 1.2;
}
.booking-animal-card__price {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #faf4e8);
    padding: 0.1rem 0.45rem;
    border-radius: 10px;
}
.booking-animal-card--active .booking-animal-card__price {
    background: rgba(171,125,63,0.22);
}

/* ---- Animal Detail (per-type qty+cage in multi-select) ---- */
.booking-animal-detail__icon svg {
    width: 20px;
    height: 20px;
}

/* ---- Animal Accordion Rows (v4) ---- */
.booking-animal-rows {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.booking-animal-row {
    border: 1.5px solid var(--booking-border, #e0dbd4);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
    background: var(--booking-card-bg, #fff);
}
.booking-animal-row + .booking-animal-row {
    margin-top: 0.5rem;
}
.booking-animal-row:hover {
    border-color: var(--booking-gold-border, #e5d5b8);
}
.booking-animal-row--active {
    border-color: var(--booking-gold, #ab7d3f);
    box-shadow: 0 2px 12px rgba(171,125,63,0.1);
    background: linear-gradient(135deg, #fefcf8 0%, #fdf8f0 100%);
}

/* Row header */
.booking-animal-row__header {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.8rem 1rem;
    cursor: pointer;
    transition: background 0.15s;
    -webkit-tap-highlight-color: transparent;
}
.booking-animal-row__header:hover {
    background: rgba(171,125,63,0.03);
}
.booking-animal-row__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: var(--booking-gold-subtle, #faf4e8);
    color: var(--booking-gold, #ab7d3f);
    flex-shrink: 0;
    transition: background 0.2s;
}
.booking-animal-row--active .booking-animal-row__icon {
    background: rgba(171,125,63,0.15);
}
.booking-animal-row__icon svg {
    width: 24px;
    height: 24px;
}
.booking-animal-row__info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}
.booking-animal-row__name {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--booking-text, #333);
    line-height: 1.3;
}
.booking-animal-row__desc {
    font-size: 0.72rem;
    color: var(--booking-text-muted, #999);
    line-height: 1.3;
    margin-top: 1px;
}
.booking-animal-row__price {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--booking-gold, #ab7d3f);
    white-space: nowrap;
    margin-right: 0.3rem;
}

/* Expanded detail */
.booking-animal-row__detail {
    padding: 0 1rem 0.85rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.booking-animal-row__qty,
.booking-animal-row__cage {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}
.booking-animal-row__qty-label,
.booking-animal-row__cage-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--booking-text-secondary, #555);
}
.booking-animal-row__cage-options {
    display: flex;
    gap: 0.35rem;
}

/* Cage toggle buttons */
.booking-animal-cage-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.35rem 0.7rem;
    border-radius: 18px;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    border: 1.5px solid var(--booking-border, #ddd);
    background: var(--booking-card-bg, #fff);
    color: var(--booking-text-secondary, #555);
    transition: all 0.2s ease;
    touch-action: manipulation;
}
.booking-animal-cage-btn:hover {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
}
.booking-animal-cage-btn--active {
    border-color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold, #ab7d3f);
    color: #fff;
}
.booking-animal-cage-btn--active:hover {
    background: var(--booking-gold-dark, #8f6830);
    border-color: var(--booking-gold-dark, #8f6830);
    color: #fff;
}
.booking-animal-cage-btn svg {
    width: 14px;
    height: 14px;
}

/* Compact counter variant */
.booking-counter--compact {
    transform: scale(0.9);
    transform-origin: right center;
}

/* Warning bar */
.booking-animal-row__warn {
    font-size: 0.75rem;
    color: #856404;
    background: #fff8e1;
    border-left: 3px solid #ffb300;
    padding: 0.45rem 0.65rem;
    border-radius: 0 6px 6px 0;
    line-height: 1.4;
}

/* Mobile */
@media (max-width: 575px) {
    .booking-animal-row__header { padding: 0.7rem 0.75rem; gap: 0.5rem; }
    .booking-animal-row__icon { width: 36px; height: 36px; border-radius: 8px; }
    .booking-animal-row__icon svg { width: 20px; height: 20px; }
    .booking-animal-row__detail { padding: 0 0.75rem 0.75rem; }
    .booking-animal-row__cage { flex-wrap: wrap; }
    .booking-animal-cage-btn { flex: 1; justify-content: center; }
}

/* ---- Animal Chips (legacy — replaced by card grid) ---- */
.booking-animal-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.3rem 0.85rem;
    border-radius: 16px;
    border: 1px solid var(--booking-border, #c8c0b3);
    background: var(--booking-card-bg, #fff);
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--booking-text-secondary, #3a3a3a);
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
    touch-action: manipulation;
}
.booking-animal-chip:hover {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
}
.booking-animal-chip--active {
    border-color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #faf6f0);
    color: var(--booking-gold, #ab7d3f);
}
.booking-animal-chip__price {
    font-size: 0.7rem;
    opacity: 0.7;
    font-weight: 400;
}
.booking-animal-chip--active .booking-animal-chip__price {
    opacity: 1;
}
.booking-animal-chip--active {
    animation: booking-chip-activate 0.25s ease;
}
@keyframes booking-chip-activate {
    0% { transform: scale(1); }
    50% { transform: scale(1.06); }
    100% { transform: scale(1); }
}

/* ---- Animal Selection Cards (legacy) ---- */
.booking-animal-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    padding: 0.75rem 0.5rem;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 0.5rem;
    background: rgba(255,255,255,0.03);
    text-align: center;
    transition: border-color 0.2s ease, background 0.2s ease;
}

.booking-animal-card:hover {
    border-color: rgba(171,125,63,0.4);
    background: rgba(171,125,63,0.05);
}

.booking-animal-card--active {
    border-color: var(--booking-gold, #ab7d3f);
    background: rgba(171,125,63,0.1);
}

.booking-animal-card__name {
    font-size: 0.85rem;
    font-weight: 500;
    color: #e0e0e0;
}

.booking-animal-card--active .booking-animal-card__name {
    color: var(--booking-gold, #ab7d3f);
}

.booking-animal-card__price {
    font-size: 0.75rem;
    color: #888;
    font-family: 'Oxygen', sans-serif;
}

.booking-animal-card--active .booking-animal-card__price {
    color: var(--booking-gold, #ab7d3f);
}

/* ---- Split Baggage Grid ---- */
.booking-baggage-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
}

.booking-baggage-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.65rem 0.75rem;
    border: 1px solid var(--booking-border, #e5e5e5);
    border-radius: 8px;
    background: var(--booking-card-bg, #fff);
    transition: border-color 0.2s ease;
}

.booking-baggage-item:hover {
    border-color: var(--booking-gold-border, #e5d5b8);
}

.booking-baggage-item__label {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--booking-text, #1a1a1a);
}

.booking-baggage-item__label svg {
    flex-shrink: 0;
    color: var(--booking-gold, #ab7d3f);
}

/* Small counter variant for baggage */
.booking-counter--sm {
    gap: 0.25rem;
}

.booking-counter--sm .booking-counter__btn {
    width: 28px;
    height: 28px;
    font-size: 0.85rem;
}

.booking-counter--sm .booking-counter__value {
    min-width: 28px;
    font-size: 0.85rem;
}

@media (max-width: 400px) {
    .booking-baggage-grid {
        grid-template-columns: 1fr;
    }
}

/* ---- Subtle Info Box (vehicle selected in step 2) ---- */
.booking-info--subtle {
    background: var(--booking-gold-subtle, #f5eedd);
    border: 1px solid var(--booking-gold-border, #e5d5b8);
    border-radius: 10px;
    padding: 0.875rem 1.25rem;
}

/* ---- Spinner Large (route loading) ---- */
.booking-spinner--lg {
    width: 40px;
    height: 40px;
    border-width: 3px;
    display: inline-block;
    border-style: solid;
    border-color: rgba(171, 125, 63, 0.2);
    border-top-color: var(--booking-gold, #ab7d3f);
    border-radius: 50%;
    animation: booking-spin 0.7s linear infinite;
}

/* ==================================================
   V2 — UX POLISH: Micro-interactions & Accessibility
   ================================================== */

/* ---- Address Swap Button ---- */
.booking-swap-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1.5px solid var(--booking-border, #e5e5e5);
    background: var(--booking-card-bg, #fff);
    cursor: pointer;
    color: var(--booking-text-secondary, #555);
    transition: all 0.25s ease;
    flex-shrink: 0;
    margin: -0.35rem auto;
    position: relative;
    z-index: 2;
}

.booking-swap-btn:hover {
    border-color: var(--booking-gold, #ab7d3f);
    color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #f5eedd);
    transform: rotate(180deg);
}

.booking-swap-btn:active {
    transform: rotate(180deg) scale(0.92);
}

.booking-swap-btn svg {
    flex-shrink: 0;
}

/* ---- Session Recovery Banner ---- */
.booking-recovery {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.15rem;
    border-radius: var(--booking-radius, 10px);
    background: var(--booking-gold-subtle, #f5eedd);
    border: 1px solid var(--booking-gold-border, rgba(171, 125, 63, 0.25));
    margin-bottom: 1rem;
    animation: booking-slideDown 0.35s ease;
}

.booking-recovery__icon {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--booking-gold, #ab7d3f);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.booking-recovery__text {
    flex: 1;
    font-size: 0.85rem;
    color: var(--booking-text, #1a1a1a);
    line-height: 1.35;
}

.booking-recovery__text strong {
    display: block;
    font-size: 0.88rem;
    margin-bottom: 0.15rem;
}

.booking-recovery__actions {
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
}

@keyframes booking-slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ---- Step Transition Animation ---- */
#booking-content {
    animation: booking-fadeIn 0.3s ease;
}

@keyframes booking-fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ---- Vehicle Selection Pulse ---- */
.vehicle-card--selected {
    animation: booking-selectPulse 0.35s ease;
}

@keyframes booking-selectPulse {
    0% { transform: scale(1); }
    40% { transform: scale(1.02); }
    100% { transform: scale(1); }
}

/* ---- Error Shake ---- */
.booking-input--error {
    animation: booking-shake 0.4s ease;
}

@keyframes booking-shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-4px); }
    40% { transform: translateX(4px); }
    60% { transform: translateX(-3px); }
    80% { transform: translateX(2px); }
}

/* ---- Enhanced Focus States (Accessibility) ---- */
.booking-input:focus-visible,
.booking-btn:focus-visible,
.booking-counter__btn:focus-visible,
.vehicle-card:focus-visible,
.booking-addon-pill:focus-visible,
.booking-payment-option:focus-within,
.booking-checkbox:focus-visible {
    outline: 2px solid var(--booking-gold, #ab7d3f);
    outline-offset: 2px;
}

/* Remove default outlines for mouse users */
.booking-input:focus:not(:focus-visible),
.booking-btn:focus:not(:focus-visible),
.booking-counter__btn:focus:not(:focus-visible),
.vehicle-card:focus:not(:focus-visible),
.booking-addon-pill:focus:not(:focus-visible) {
    outline: none;
}

/* ---- Reduced Motion Preference ---- */
/* ---- Data Row (recap in step 3) ---- */
.booking-data-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 0.45rem 0;
    font-size: 0.85rem;
    border-bottom: 1px solid var(--booking-border-light, #f0f0f0);
}

.booking-data-row:last-of-type {
    border-bottom: none;
}

.booking-data-row__label {
    color: var(--booking-text-secondary, #555);
    font-weight: 500;
    flex-shrink: 0;
    margin-right: 1rem;
}

.booking-data-row__value {
    text-align: right;
    font-weight: 600;
    color: var(--booking-text, #1a1a1a);
    word-break: break-word;
}

/* ---- Payment Option Cards (step 3) ---- */
.booking-payment-option {
    display: flex;
    gap: 0.75rem;
    padding: 0.875rem 1.15rem;
    border: 1.5px solid var(--booking-border, #e5e5e5);
    border-radius: 10px;
    margin-bottom: 0.6rem;
    cursor: pointer;
    transition: all 0.2s ease;
    background: var(--booking-card-bg, #fff);
    align-items: flex-start;
}

.booking-payment-option:hover {
    border-color: var(--booking-gold-border, rgba(171, 125, 63, 0.4));
}

.booking-payment-option--active {
    border-color: var(--booking-gold, #ab7d3f);
    background: var(--booking-gold-subtle, #f5eedd);
}

.booking-payment-option input[type="radio"] {
    margin-top: 0.25rem;
    accent-color: var(--booking-gold, #ab7d3f);
    flex-shrink: 0;
}

.booking-payment-option__title {
    font-weight: 700;
    font-size: 0.9rem;
    margin-bottom: 0.2rem;
}

.booking-payment-option__desc {
    font-size: 0.8rem;
    color: var(--booking-text-secondary, #555);
    line-height: 1.4;
}

.booking-payment-option__badges {
    display: flex;
    gap: 0.35rem;
    margin-top: 0.4rem;
    flex-wrap: wrap;
}

.booking-payment-badge {
    padding: 0.15rem 0.5rem;
    border-radius: 4px;
    font-size: 0.68rem;
    font-weight: 700;
    background: rgba(171, 125, 63, 0.12);
    color: var(--booking-gold, #ab7d3f);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* ---- Price Display (amount to pay - step 3) ---- */
.booking-price-display {
    text-align: center;
    padding: 1.25rem 1rem;
    border-radius: var(--booking-radius, 10px);
    background: var(--booking-dark, #1a1a1a);
    color: #fff;
}

.booking-price-display__label {
    font-size: 0.78rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    opacity: 0.7;
    margin-bottom: 0.35rem;
}

.booking-price-display__amount {
    font-size: 2rem;
    font-weight: 800;
    color: var(--booking-gold-light, #c4a265);
    line-height: 1.1;
}

.booking-price-display__sub {
    font-size: 0.78rem;
    opacity: 0.6;
    margin-top: 0.35rem;
}

/* ---- CGV Section (step 3) ---- */
.booking-cgv {
    padding: 0.75rem;
    border-radius: 8px;
    border: 1px solid transparent;
    transition: border-color 0.2s ease;
}

.booking-cgv--error {
    border-color: #dc3545;
    background: rgba(220, 53, 69, 0.04);
}

.booking-cgv__text {
    font-size: 0.82rem;
    line-height: 1.5;
}

.booking-cgv__details {
    font-size: 0.8rem;
}

/* ---- Policy Grid (cancellation table) ---- */
.booking-policy-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0.3rem 1rem;
    font-size: 0.8rem;
}

.booking-policy-grid__label {
    color: var(--booking-text-secondary, #555);
}

.booking-policy-grid__value {
    font-weight: 700;
    text-align: right;
    color: var(--booking-text, #1a1a1a);
}

/* ---- Checkbox label ---- */
.booking-checkbox-label {
    display: flex;
    gap: 0.65rem;
    cursor: pointer;
    align-items: flex-start;
}

.booking-checkbox {
    margin-top: 0.2rem;
    accent-color: var(--booking-gold, #ab7d3f);
    flex-shrink: 0;
    width: 18px;
    height: 18px;
}

.booking-checkbox-title {
    font-size: 0.88rem;
    display: block;
}

.booking-checkbox-desc {
    font-size: 0.8rem;
    color: var(--booking-text-secondary, #555);
    margin-top: 0.15rem;
}

/* ---- Toggle Group ---- */
.booking-toggle-group {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

/* ---- Readonly Input ---- */
.booking-input--readonly {
    background: var(--booking-bg, #fafafa);
    border-color: transparent;
    cursor: default;
    color: var(--booking-text, #1a1a1a);
    font-weight: 500;
}

/* ---- Price Breakdown Section ---- */
.booking-price-breakdown {
    background: var(--booking-card-bg, #fff);
    border: 1px solid var(--booking-border, #e5e5e5);
    border-radius: var(--booking-radius, 10px);
    padding: 1rem 1.25rem;
}

.booking-price-summary-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.85rem;
    padding: 0.3rem 0;
    color: var(--booking-text-secondary, #555);
}

.booking-price-summary-total {
    display: flex;
    justify-content: space-between;
    font-size: 1.05rem;
    font-weight: 700;
    padding: 0.3rem 0;
}

/* ---- Section Title Gold ---- */
.booking-section-title--gold {
    color: var(--booking-gold, #ab7d3f);
    font-size: 0.95rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
}

/* ---- Char Counter (comment field) ---- */
.booking-char-counter {
    font-size: 0.72rem;
    color: var(--booking-text-muted, #6b6b6b);
    white-space: nowrap;
    flex-shrink: 0;
}

.booking-char-counter--warn {
    color: #dc3545;
    font-weight: 600;
}

/* ---- Price Accent Small ---- */
.booking-price-accent--sm {
    font-size: 0.8rem;
    font-weight: 600;
}

/* ---- Return Fields (step 1 toggle area) ---- */
.booking-return-toggle {
    display: flex;
    gap: 0.65rem;
    cursor: pointer;
    padding: 0.75rem 1rem;
    border: 1.5px solid var(--booking-border, #e5e5e5);
    border-radius: 10px;
    background: var(--booking-card-bg, #fff);
    transition: all 0.2s ease;
    align-items: flex-start;
}

.booking-return-toggle:hover {
    border-color: var(--booking-gold-border, rgba(171, 125, 63, 0.4));
}

.booking-return-toggle__checkbox {
    margin-top: 0.2rem;
    accent-color: var(--booking-gold, #ab7d3f);
    flex-shrink: 0;
    width: 18px;
    height: 18px;
}

.booking-return-toggle__label {
    flex: 1;
}

.booking-return-toggle__label strong {
    display: block;
    font-size: 0.88rem;
}

.booking-return-toggle__hint {
    display: block;
    font-size: 0.78rem;
    color: var(--booking-text-secondary, #555);
    margin-top: 0.15rem;
}

.booking-return-fields {
    padding: 0.75rem 1rem;
    border: 1px solid var(--booking-gold-border, rgba(171, 125, 63, 0.25));
    border-radius: 10px;
    background: var(--booking-gold-subtle, #f5eedd);
}

/* ---- Vehicle Card Image ---- */
.vehicle-card__image {
    overflow: hidden;
    border-radius: 6px;
    margin-bottom: 0.5rem;
}

.vehicle-card__image img {
    transition: transform 0.3s ease;
}

.vehicle-card:hover .vehicle-card__image img {
    transform: scale(1.03);
}

/* ---- Link Inline (for CGV inline toggle) ---- */
.booking-link--inline {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    color: var(--booking-gold, #ab7d3f);
    text-decoration: underline;
    cursor: pointer;
}

.booking-link--inline:hover {
    color: var(--booking-gold-light, #c4a265);
}

.booking-link--sm {
    font-size: 0.78rem;
}

/* ---- Info Gold (airport/station detected) ---- */
.booking-info--gold {
    background: var(--booking-gold-subtle, #f5eedd);
    border: 1px solid var(--booking-gold-border, rgba(171, 125, 63, 0.25));
    border-radius: 8px;
    padding: 0.75rem 1rem;
    font-size: 0.85rem;
}

.booking-info--compact {
    font-size: 0.82rem;
    padding: 0.65rem 0.85rem;
    border-radius: 8px;
    background: var(--booking-bg, #fafafa);
    border: 1px solid var(--booking-border, #e5e5e5);
}

/* ---- Section title (generic) ---- */
.booking-section-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--booking-text, #1a1a1a);
    margin-bottom: 0.75rem;
}

/* ---- Hint sizes ---- */
.booking-hint--xs {
    font-size: 0.72rem;
}

/* ---- Mobile: step navigation sticky improvement ---- */
@media (max-width: 768px) {
    .booking-nav {
        position: sticky;
        bottom: 60px;
        background: var(--booking-card-bg, #fff);
        padding: 0.75rem 0;
        z-index: 5;
        border-top: 1px solid var(--booking-border-light, #f0f0f0);
        margin: 0 -1rem;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    /* Improve touch targets on mobile */
    .booking-counter__btn {
        min-width: 40px;
        min-height: 40px;
    }

    .booking-addon-pill {
        padding: 0.55rem 1.15rem;
        font-size: 0.85rem;
    }

    .booking-payment-option {
        padding: 1rem;
    }

    /* Recovery banner compact on mobile */
    .booking-recovery {
        flex-direction: column;
        text-align: center;
    }

    .booking-recovery__actions {
        width: 100%;
        justify-content: center;
    }
}

/* ===========================================
 * UX AUDIT FIXES — Premium Polish (March 2026)
 * Focus states, transitions, contrast, accessibility,
 * mobile touch targets, loading states, animations
 * =========================================== */

/* ---- 1. FOCUS STATES (Keyboard Accessibility) ---- */
.booking-btn:focus-visible {
    outline: 3px solid var(--booking-gold);
    outline-offset: 2px;
}

.booking-btn--lg:focus-visible {
    outline: 3px solid var(--booking-gold);
    outline-offset: 3px;
}

.booking-addon-pill:focus-visible,
.booking-comfort-card__title:focus-visible,
.booking-payment-option:focus-visible {
    outline: 2px solid var(--booking-gold);
    outline-offset: 2px;
}

.vehicle-card:focus-visible {
    outline: 3px solid var(--booking-gold);
    outline-offset: 2px;
    box-shadow: var(--booking-shadow-hover);
}

.booking-pill:focus-visible {
    outline: 2px solid var(--booking-gold);
    outline-offset: 2px;
}

.booking-return-toggle:focus-visible {
    outline: 2px solid var(--booking-gold);
    outline-offset: 2px;
}

/* Skip link focus */
.booking-skip-link:focus {
    outline: 3px solid #fff;
    outline-offset: 2px;
}

/* ---- 2. BUTTON STATES (Active, Disabled) ---- */
.booking-btn:active:not(:disabled) {
    transform: scale(0.97);
    transition: transform 0.08s ease;
}

.booking-btn:disabled,
.booking-btn[disabled] {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
}

.booking-btn--primary:disabled {
    background: var(--booking-gold);
}

/* ---- 3. INPUT TRANSITIONS (Premium Smoothness) ---- */
.booking-input {
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

/* Improve error contrast (WCAG AA) */
.booking-input--error,
.booking-input.is-invalid {
    border-color: #c53030;
    box-shadow: 0 0 0 1px #c53030;
}

.booking-error {
    color: #c53030;
}

/* Readonly field styling */
.booking-input--readonly,
.booking-input[readonly] {
    cursor: default;
    opacity: 0.75;
    border-left: 3px solid var(--booking-gold);
    background: #fafafa;
}

/* ---- 4. TEXT CONTRAST FIXES (WCAG AA) ---- */
.booking-hint,
.booking-label--hint {
    color: #777;  /* Upgraded from #999 for 4.5:1 contrast */
}

.booking-text-muted {
    color: #777;
}

/* ---- 5. COUNTER COMPONENT — Touch Targets & States ---- */
.booking-counter__btn {
    min-width: 44px;
    min-height: 44px;
    touch-action: manipulation;
}

.booking-counter__btn:disabled,
.booking-counter__btn[disabled] {
    opacity: 0.3;
    cursor: not-allowed;
    background: #f0f0f0;
    color: #bbb;
}

.booking-counter__btn:disabled:hover {
    background: #f0f0f0;
    color: #bbb;
}

/* Counter value bump animation */
@keyframes booking-counter-bump {
    0% { transform: scale(1); }
    50% { transform: scale(1.15); }
    100% { transform: scale(1); }
}

.booking-counter__value--bump {
    animation: booking-counter-bump 0.2s ease;
}

/* ---- 6. ADDON PILL ANIMATION ---- */
@keyframes booking-pill-activate {
    0% { transform: scale(1); }
    50% { transform: scale(1.05); }
    100% { transform: scale(1); }
}

.booking-addon-pill--active {
    animation: booking-pill-activate 0.25s ease;
}

.booking-addon-pill {
    transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
    touch-action: manipulation;
}

/* ---- 7. VEHICLE CARD SELECTION — Better Feedback ---- */
.vehicle-card {
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    cursor: pointer;
}

.vehicle-card:hover:not(.vehicle-card--selected) {
    transform: translateY(-2px);
    box-shadow: var(--booking-shadow-hover);
}

.vehicle-card--selected {
    transform: translateY(-1px);
    border-color: var(--booking-gold);
    box-shadow: 0 0 0 2px var(--booking-gold), var(--booking-shadow-hover);
}

@keyframes booking-card-select {
    0% { transform: scale(1); }
    50% { transform: scale(1.02); }
    100% { transform: scale(1) translateY(-1px); }
}

.vehicle-card--selected {
    animation: booking-card-select 0.3s ease;
}

/* ---- 8. LOADING SKELETON (HTMX step transitions) ---- */
.htmx-indicator {
    display: none;
}

.htmx-request .htmx-indicator,
.htmx-request.htmx-indicator {
    display: block;
}

@keyframes booking-shimmer {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}

.booking-skeleton {
    background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: booking-shimmer 1.5s ease infinite;
    border-radius: var(--booking-radius-sm);
    min-height: 20px;
}

.booking-skeleton--line { height: 16px; margin-bottom: 0.5rem; }
.booking-skeleton--card { height: 120px; margin-bottom: 1rem; }

/* ---- 9. TOAST ACCESSIBILITY ---- */
.booking-toast {
    /* role="alert" should be set in HTML */
    position: relative;
}

/* ---- 10. PROGRESS BAR — Checkmark Animation ---- */
@keyframes booking-check-appear {
    0% { opacity: 0; transform: scale(0.3); }
    50% { opacity: 1; transform: scale(1.15); }
    100% { opacity: 1; transform: scale(1); }
}

.booking-pill__check svg {
    animation: booking-check-appear 0.35s ease;
}

/* ---- 11. MOBILE SAFE AREAS ---- */
@supports (padding: max(0px)) {
    .booking-mobile-bar {
        padding-bottom: max(0.65rem, env(safe-area-inset-bottom));
    }
}

/* ---- 12. PRICE HIGHLIGHT (Gold accent) ---- */
.booking-summary__value--price {
    color: var(--booking-gold);
    font-weight: 800;
}

.booking-summary__value--highlight {
    color: var(--booking-gold);
    font-weight: 700;
}

/* ---- 13. RETURN TRIP — Smooth expand ---- */
[x-show][x-transition] {
    transition: opacity 0.3s ease, transform 0.3s ease;
}

/* ---- 14. TOOLTIPS — Disable on touch devices ---- */
@media (hover: none) {
    .booking-tooltip::after,
    .booking-tooltip::before {
        display: none !important;
    }
}

/* ---- 15. SWAP BUTTON — Better disabled state ---- */
.booking-swap-btn:disabled,
.booking-swap-btn[disabled] {
    opacity: 0.3;
    cursor: not-allowed;
}

/* ---- 16. FONT SMOOTHING (Premium text rendering) ---- */
.booking-page {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* ---- 17. FORM GROUP TRANSITIONS (Section expand/collapse) ---- */
.booking-comfort-card,
.booking-options-group {
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.booking-comfort-card:hover {
    border-color: var(--booking-gold-border);
}

/* ---- 18. RECAP ROWS — Subtle stripes ---- */
.booking-recap-section .booking-summary__row:nth-child(even) {
    background: #fafafa;
    border-radius: 4px;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

/* ---- 19. PAYMENT OPTION — Selected state polish ---- */
.booking-payment-option--active {
    border-color: var(--booking-gold);
    background: var(--booking-gold-subtle);
    box-shadow: 0 0 0 2px var(--booking-gold-border);
}

/* ---- 20. MOBILE-SPECIFIC ADJUSTMENTS ---- */
@media (max-width: 576px) {
    /* Counter touch targets */
    .booking-counter__btn {
        min-width: 44px;
        min-height: 44px;
        font-size: 1.2rem;
    }

    /* Better spacing for small screens */
    .booking-card {
        padding: 1rem;
    }

    /* Price breakdown readable on mobile */
    .booking-price-breakdown {
        padding: 0.875rem;
        font-size: 0.85rem;
    }

    /* Modal fullscreen on mobile */
    .booking-modal {
        max-height: 95vh;
        border-radius: 0.75rem;
    }

    /* Navigation buttons full width */
    .booking-nav {
        flex-direction: column;
        gap: 0.75rem;
    }

    .booking-nav .booking-btn {
        width: 100%;
    }

    /* Checkbox alignment on narrow screens */
    .booking-cgv {
        gap: 0.5rem;
    }

    .booking-cgv label {
        font-size: 0.85rem;
    }

    /* Ensure counter buttons stay at WCAG min touch target */
    .booking-counter__btn {
        width: 44px;
        height: 44px;
        font-size: 1.2rem;
    }
}

/* ============================================
   Welcome Logo Choice (name sign section)
   ============================================ */
.welcome-logo-choice {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem;
    border: 2px solid var(--booking-border, #e0e0e0);
    border-radius: 0.5rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    min-width: 100px;
}
.welcome-logo-choice--active {
    border-color: var(--booking-gold, #ab7d3f);
    box-shadow: 0 0 0 2px rgba(171, 125, 63, 0.2);
}
.welcome-logo-choice__preview {
    width: 90px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.35rem;
    overflow: hidden;
}
.welcome-logo-choice__preview img {
    max-width: 70px;
    max-height: 36px;
    object-fit: contain;
}
.welcome-logo-choice__label {
    font-size: 0.7rem;
    color: var(--booking-text-muted, #777);
    font-weight: 500;
}
.welcome-logo-upload {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}

/* ============================================
   Pickup Sign Mini Preview (booking form)
   ============================================ */
.pickup-sign-preview {
    border-radius: 0.75rem;
    padding: 1.25rem 1.5rem;
    text-align: center;
    transition: background 0.4s ease, border-color 0.4s ease;
    border: 1px solid rgba(201, 168, 76, 0.25);
    box-shadow: 0 2px 16px rgba(0,0,0,0.1);
    max-width: 340px;
    position: relative;
    overflow: hidden;
}
.pickup-sign-preview::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,0.08) 100%);
}
.pickup-sign-preview > * {
    position: relative;
    z-index: 1;
}
.pickup-sign-preview__logo {
    margin-bottom: 0.5rem;
    min-height: 28px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.pickup-sign-preview__logo img {
    max-height: 32px;
    max-width: 120px;
    object-fit: contain;
}
.pickup-sign-preview__welcome {
    font-size: 0.6rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    font-weight: 400;
    margin-bottom: 0.2rem;
    color: #c9a96e;
}
.pickup-sign-preview__name {
    font-family: 'Cormorant Garamond', 'Georgia', serif;
    font-size: 1.4rem;
    font-weight: 400;
    letter-spacing: 0.1em;
    line-height: 1.15;
    word-break: break-word;
    text-transform: uppercase;
}
.pickup-sign-preview__ornament {
    width: 40px;
    height: 2px;
    margin: 0.5rem auto 0;
    border-radius: 1px;
}
/* Brand logo at bottom of pickup preview — keep small & discreet */
.pickup-sign-preview__brand-logo {
    max-height: 14px;
    max-width: 60px;
    object-fit: contain;
}
/* All images inside preview — enforce max bounds */
.pickup-sign-preview img {
    max-width: 140px;
    max-height: 36px;
    object-fit: contain;
}
