/* ===== BookAtLane ===== */
.bal-quote-form, .bal-booking-flow, .bal-vehicle-details, .bal-confirmation {
    --bal-primary: #1f6feb;
    --bal-primary-dark: #155cc4;
    --bal-success: #1f8a4c;
    --bal-text: #1a1a1a;
    --bal-muted: #6a6f76;
    --bal-border: #e3e5e8;
    --bal-bg: #f7f8fa;
    --bal-radius: 8px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    color: var(--bal-text);
}

/* Forms */
.bal-form .bal-field { margin-bottom: 1rem; }
.bal-form label { display: block; font-weight: 600; margin-bottom: .35rem; font-size: .9rem; }
.bal-form input, .bal-form select, .bal-customer-form input, .bal-customer-form select, .bal-date-picker input {
    width: 100%; padding: .65rem .8rem; border: 1px solid var(--bal-border);
    border-radius: var(--bal-radius); font-size: 1rem; background: #fff;
}
.bal-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* Buttons */
.bal-btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    padding: .7rem 1.2rem; border: 0; border-radius: var(--bal-radius); cursor: pointer;
    font-weight: 600; font-size: 1rem; text-decoration: none; transition: background .15s; }
.bal-btn-primary { background: var(--bal-primary); color: #fff; }
.bal-btn-primary:hover { background: var(--bal-primary-dark); }
.bal-btn-secondary { background: #fff; color: var(--bal-text); border: 1px solid var(--bal-border); }
.bal-btn-secondary:hover { background: var(--bal-bg); }
.bal-btn-lg { padding: .9rem 1.6rem; font-size: 1.05rem; }
.bal-btn.is-disabled { pointer-events: none; opacity: .5; }

/* Spinner */
.bal-spinner { width: 16px; height: 16px; border: 2px solid #fff; border-top-color: transparent;
    border-radius: 50%; animation: bal-spin .8s linear infinite; }
@keyframes bal-spin { to { transform: rotate(360deg); } }

/* Errors / notices */
.bal-form-error, .bal-stripe-error { background: #ffe8e8; color: #a31a1a; padding: .7rem 1rem;
    border-radius: var(--bal-radius); margin: .5rem 0; }
.bal-notice { padding: .8rem 1rem; border-radius: var(--bal-radius); margin-bottom: 1rem; }
.bal-notice-success { background: #e7f6ec; color: #155724; border: 1px solid #b9e1c3; }
.bal-muted { color: var(--bal-muted); font-size: .9rem; }

/* Modal */
.bal-modal { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; }
.bal-modal-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.bal-modal-content { position: relative; background: #fff; max-width: 480px; width: 90%;
    border-radius: var(--bal-radius); padding: 1.5rem; box-shadow: 0 10px 40px rgba(0,0,0,.2); }
.bal-modal-close { position: absolute; top: .5rem; right: .8rem; background: none; border: 0; font-size: 1.5rem; cursor: pointer; }
.bal-modal-body { margin: 1rem 0; }
.bal-modal-footer { display: flex; gap: .5rem; justify-content: flex-end; }

/* Vehicle details block */
.bal-vehicle-card { display: flex; gap: 1rem; align-items: center; padding: 1rem; background: var(--bal-bg);
    border-radius: var(--bal-radius); border: 1px solid var(--bal-border); }
.bal-vehicle-plate, .bal-basket-plate { background: #ffd400; color: #000; font-weight: 700;
    letter-spacing: 1px; padding: .4rem .8rem; border-radius: 4px; font-family: "Charles Wright", monospace;
    border: 1px solid #b39a00; font-size: 1.1rem; display: inline-block; }
.bal-vehicle-title { font-weight: 700; font-size: 1.1rem; }
.bal-vehicle-meta span { display: inline-block; margin-right: .5rem; color: var(--bal-muted); font-size: .9rem; }
.bal-mot-due { margin-top: .3rem; font-weight: 600; color: var(--bal-success); }

/* Booking flow */
.bal-steps-nav { display: flex; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.bal-step-dot { display: flex; align-items: center; gap: .5rem; padding: .5rem 1rem;
    border-radius: 40px; background: var(--bal-bg); color: var(--bal-muted); font-weight: 600; }
.bal-step-dot span { display: inline-flex; width: 24px; height: 24px; align-items: center;
    justify-content: center; background: #ddd; color: #fff; border-radius: 50%; font-size: .85rem; }
.bal-step-dot.is-active { background: var(--bal-primary); color: #fff; }
.bal-step-dot.is-active span { background: rgba(255,255,255,.3); }

.bal-flow-grid { display: grid; grid-template-columns: 70% 30%; gap: 1.5rem; align-items: start; }
@media (max-width: 800px) { .bal-flow-grid { grid-template-columns: 1fr; } }

.bal-flow-main { background: #fff; padding: 1.5rem; border: 1px solid var(--bal-border); border-radius: var(--bal-radius); }
.bal-basket { background: #fff; padding: 1.25rem; border: 1px solid var(--bal-border); border-radius: var(--bal-radius); position: sticky; top: 1rem; }
.bal-basket-title { margin: 0 0 .8rem; font-size: 1.1rem; }
.bal-basket-label { font-size: .75rem; text-transform: uppercase; letter-spacing: .5px; color: var(--bal-muted); margin-bottom: .3rem; }
.bal-basket-section { margin-bottom: .6rem; }
.bal-divider { border: 0; border-top: 1px solid var(--bal-border); margin: .8rem 0; }
.bal-basket-items { list-style: none; padding: 0; margin: 0; }
.bal-basket-items li { display: flex; justify-content: space-between; gap: .5rem; padding: .35rem 0; font-size: .92rem; }
.bal-basket-item-name { display: flex; align-items: center; gap: .4rem; }
.bal-basket-remove { background: transparent; border: 0; color: var(--bal-muted); cursor: pointer; font-size: 1.2rem; line-height: 1; }
.bal-was { text-decoration: line-through; color: var(--bal-muted); margin-right: .35rem; font-size: .85rem; }
.bal-basket-totals { margin-top: .8rem; border-top: 1px dashed var(--bal-border); padding-top: .6rem; }
.bal-row { display: flex; justify-content: space-between; padding: .2rem 0; }
.bal-row-total { font-weight: 700; font-size: 1.1rem; padding-top: .4rem; }
.bal-row-discount { color: var(--bal-success); }

/* Step 1 */
.bal-category-switch { margin: 1rem 0; display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.bal-category-switch select { padding: .4rem .6rem; border-radius: var(--bal-radius); border: 1px solid var(--bal-border); }
.bal-addons-title { margin-top: 1.5rem; }
.bal-addons { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1rem; margin-top: .8rem; }
.bal-addon-card { border: 1px solid var(--bal-border); border-radius: var(--bal-radius); padding: 1rem; background: #fff; display: flex; flex-direction: column; }
.bal-addon-card.is-added { border-color: var(--bal-success); background: #f4fbf6; }
.bal-addon-head { display: flex; justify-content: space-between; align-items: start; gap: .5rem; }
.bal-addon-head h4 { margin: 0; font-size: 1rem; }
.bal-badge { background: var(--bal-success); color: #fff; padding: .15rem .5rem; border-radius: 12px; font-size: .75rem; font-weight: 600; }
.bal-addon-foot { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: .6rem; }

.bal-step-actions { display: flex; gap: .8rem; justify-content: space-between; margin-top: 1.5rem; flex-wrap: wrap; }

/* Step 2 */
.bal-datetime { display: grid; grid-template-columns: 240px 1fr; gap: 1.5rem; margin: 1rem 0; }
@media (max-width: 700px) { .bal-datetime { grid-template-columns: 1fr; } }
.bal-slot-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: .5rem; }
.bal-slot { padding: .55rem .4rem; background: #fff; border: 1px solid var(--bal-border); border-radius: var(--bal-radius); cursor: pointer; text-align: center; font-weight: 600; }
.bal-slot:hover { border-color: var(--bal-primary); }
.bal-slot.is-selected { background: var(--bal-primary); color: #fff; border-color: var(--bal-primary); }

/* Step 3 */
.bal-payment-options { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 1rem 0; }
@media (max-width: 600px) { .bal-payment-options { grid-template-columns: 1fr; } }
.bal-radio-card { display: flex; gap: .8rem; padding: 1rem; border: 1px solid var(--bal-border); border-radius: var(--bal-radius); cursor: pointer; align-items: flex-start; }
.bal-radio-card input { margin-top: .25rem; }
.bal-radio-card p { margin: .2rem 0 0; color: var(--bal-muted); font-size: .9rem; }
.bal-stripe-wrap { padding: 1rem; border: 1px solid var(--bal-border); border-radius: var(--bal-radius); margin: 1rem 0; }

/* Confirmation */
.bal-confirmation-hero { text-align: center; padding: 1.5rem; }
.bal-tick { width: 64px; height: 64px; line-height: 64px; background: var(--bal-success); color: #fff; border-radius: 50%; font-size: 2rem; margin: 0 auto 1rem; }
.bal-confirmation-summary { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; background: var(--bal-bg); padding: 1.5rem; border-radius: var(--bal-radius); margin-bottom: 2rem; }
@media (max-width: 700px) { .bal-confirmation-summary { grid-template-columns: 1fr; } }
.bal-confirm-map { height: 260px; margin-top: .8rem; border-radius: var(--bal-radius); }
.bal-pill { display: inline-block; padding: .15rem .6rem; background: #eee; border-radius: 20px; font-size: .8rem; }
.bal-pill-paid { background: var(--bal-success); color: #fff; }
.bal-next-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
@media (max-width: 800px) { .bal-next-cards { grid-template-columns: 1fr; } }
.bal-next-card { padding: 1.2rem; border: 1px solid var(--bal-border); border-radius: var(--bal-radius); background: #fff; }
.bal-next-card h4 { margin-top: 0; }

.bal-empty-state { text-align: center; padding: 3rem 1rem; }