/* ============================================================================
   Appointment Booking Widget — Premium mobile-first redesign
   ----------------------------------------------------------------------------
   Critical: selectors below that *match the original API used by booking.js*
   (`.step-content`, `.d-none`, `.btn-primary` / `.btn-success`, `.time-slot-btn`,
   `.personnel-card`, `.appointment-card`, `.modern-modal-content`,
   `.input-group-modern`, `.appointment-type-card .btn-check:checked + label`,
   `.custom-input-group`, `.upload-zone`, `.date-selector-wrapper`,
   `.custom-date-input`, `.ticket-card`, `.rating-stars`, etc.) are preserved
   verbatim so behaviour is not affected. The new `apt-*` classes layer the
   visual redesign on top.
   ============================================================================ */

/* ---------------------------------------------------------------------------
   Design tokens — scoped to the widget. Falls back to host-template brand vars
   (`--dp-brand`, etc.) when present so the widget feels native on any template.
   --------------------------------------------------------------------------- */
:root {
    --primary-color: #5B5FE9;
    --bg-surface: #ffffff;
    --bg-input: #F3F4F6;
    --text-main: #1F2937;
    --text-muted: #6B7280;
}

.appointment-widget,
#bookingModal,
#statusModal,
#commentsModal,
#addCommentModal,
#ratingModal {
    --apt-brand: var(--dp-brand, #5B5FE9);
    --apt-brand-dark: var(--dp-brand-dark, #4338CA);
    --apt-brand-soft: var(--dp-brand-soft, #EEF0FF);
    --apt-brand-mist: var(--dp-brand-mist, #F6F7FE);
    --apt-accent: var(--dp-gold, #F59E0B);
    --apt-success: #10B981;
    --apt-success-soft: #D1FAE5;
    --apt-danger: #EF4444;
    --apt-warning: #F59E0B;
    --apt-info: #0EA5E9;

    --apt-text: var(--dp-text, #0F172A);
    --apt-text-soft: var(--dp-text-soft, #334155);
    --apt-muted: var(--dp-muted, #64748B);
    --apt-border: var(--dp-border, #E2E8F0);
    --apt-border-soft: var(--dp-border-soft, #F1F5F9);
    --apt-surface: #F8FAFC;
    --apt-card: #ffffff;

    --apt-radius-sm: 10px;
    --apt-radius: 14px;
    --apt-radius-lg: 20px;
    --apt-radius-xl: 28px;

    --apt-shadow-sm: 0 2px 8px rgba(91, 95, 233, .06);
    --apt-shadow: 0 14px 36px rgba(91, 95, 233, .10);
    --apt-shadow-lg: 0 24px 60px rgba(91, 95, 233, .16);

    --apt-transition: .25s cubic-bezier(.4, 0, .2, 1);

    /* Sticky-footer height (used to pad body bottom on mobile) */
    --apt-footer-h: 88px;

    /* iOS safe-area */
    --apt-safe-b: env(safe-area-inset-bottom, 0px);
}

/* ============================================================================
   Launch button — the pill rendered inside the host page
   ============================================================================ */
.apt-launch {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    padding: .9rem 1.5rem .9rem 1.25rem;
    background: linear-gradient(135deg, var(--apt-brand) 0%, var(--apt-brand-dark) 100%);
    color: #fff !important;
    border-radius: 999px;
    font-weight: 800;
    font-size: 1rem;
    text-decoration: none;
    cursor: pointer;
    box-shadow: 0 12px 28px rgba(91, 95, 233, .28);
    transition: transform var(--apt-transition), box-shadow var(--apt-transition), filter var(--apt-transition);
    border: none;
    line-height: 1;
}
.apt-launch:hover { transform: translateY(-2px); box-shadow: 0 18px 36px rgba(91, 95, 233, .36); filter: brightness(1.05); color: #fff !important; }
.apt-launch:active { transform: translateY(0); }
.apt-launch__icon {
    width: 32px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255, 255, 255, .2);
    border-radius: 50%;
    font-size: .95rem;
}
.apt-launch__text { font-weight: 800; letter-spacing: -.01em; }
.apt-launch__arrow {
    margin-inline-start: auto;
    font-size: .75rem;
    opacity: .8;
    transition: transform var(--apt-transition);
}
.apt-launch:hover .apt-launch__arrow { transform: translateX(-3px); }

/* ============================================================================
   Pre-launch alerts (owner & visitor)
   ============================================================================ */
.apt-alert {
    border: none;
    border-radius: var(--apt-radius-lg);
    padding: 1.25rem 1.4rem;
    display: flex;
    flex-direction: column;
    gap: .85rem;
    line-height: 1.85;
    box-shadow: var(--apt-shadow-sm);
}
.apt-alert--warning {
    background: #FFFBEB;
    color: #78350F;
    border: 1px solid #FDE68A;
}
.apt-alert--danger {
    background: #FEF2F2;
    color: #7F1D1D;
    border: 1px solid #FCA5A5;
}
.apt-alert > i:first-child { font-size: 1.2rem; opacity: .8; }
.apt-alert__title { font-weight: 600; }
.apt-alert__link { color: var(--apt-brand); font-weight: 700; text-decoration: none; padding: 0 .2rem; }
.apt-alert__link:hover { text-decoration: underline; }
.apt-alert__issues {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .45rem;
}
.apt-alert__issue {
    display: flex;
    align-items: flex-start;
    gap: .55rem;
    font-size: .92rem;
    padding: .55rem .8rem;
    background: rgba(255, 255, 255, .65);
    border-radius: var(--apt-radius);
}
.apt-alert__issue i { margin-top: .25rem; flex-shrink: 0; }
.apt-alert__issue--err i { color: var(--apt-danger); }
.apt-alert__issue--warn i { color: var(--apt-warning); }
.apt-alert__hint { color: var(--apt-info); font-size: .82rem; }

/* ============================================================================
   Booking Modal — fullscreen on mobile, dialog on desktop
   ============================================================================ */
#bookingModal {
    background-color: rgba(15, 23, 42, .55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
#bookingModal .modal-dialog {
    max-width: 100%;
    margin: 0 !important;
    height: 100%;
}
#bookingModal .modal-content {
    max-height: 100vh;
    height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--apt-surface);
    color: var(--apt-text);
    border-radius: 0;
}

/* On desktop, lift it into a centred card */
@media (min-width: 768px) {
    #bookingModal .modal-dialog {
        max-width: 760px;
        margin: 2rem auto !important;
        height: calc(100vh - 4rem);
    }
    #bookingModal .modal-content {
        height: calc(100vh - 4rem);
        max-height: calc(100vh - 4rem);
        border-radius: var(--apt-radius-xl);
        overflow: hidden;
        box-shadow: var(--apt-shadow-lg);
    }
}

/* Header */
#bookingModal .modal-header,
.apt-modal__header {
    background: rgba(255, 255, 255, .96);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid var(--apt-border-soft);
    position: sticky;
    top: 0;
    z-index: 1020;
    padding: .85rem 1.15rem;
    display: flex;
    align-items: center;
    gap: .75rem;
    min-height: 60px;
}
.apt-modal__title-wrap { flex: 1; text-align: center; min-width: 0; }
.apt-modal__title {
    font-weight: 800;
    font-size: 1rem;
    color: var(--apt-text);
    letter-spacing: -.01em;
}

.apt-back-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .5rem .8rem;
    background: var(--apt-brand-soft);
    color: var(--apt-brand) !important;
    border: none;
    border-radius: 999px;
    font-weight: 700;
    font-size: .82rem;
    text-decoration: none;
    transition: var(--apt-transition);
}
.apt-back-btn:hover { background: var(--apt-brand); color: #fff !important; }
.apt-back-btn i { font-size: .75rem; }

.apt-close-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: var(--apt-surface);
    opacity: .9;
    transition: var(--apt-transition);
    background-position: center;
    background-size: .8rem;
}
.apt-close-btn:hover { opacity: 1; background-color: var(--apt-border-soft); transform: rotate(90deg); }

/* ============================================================================
   Progress indicator (4 dots + animated fill bar)
   ============================================================================ */
.apt-progress {
    background: #fff;
    padding: 1rem 1.25rem .85rem;
    position: sticky;
    top: 60px;
    z-index: 1019;
    border-bottom: 1px solid var(--apt-border-soft);
}
.apt-progress__track {
    height: 3px;
    background: var(--apt-border-soft);
    border-radius: 999px;
    margin: 0 18px .85rem;
    position: relative;
    overflow: hidden;
}
.apt-progress__fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--apt-brand), var(--apt-accent));
    border-radius: 999px;
    transition: width .45s cubic-bezier(.4, 0, .2, 1);
}
.apt-progress__dots {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .5rem;
}
.apt-progress__dot {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .25rem;
    text-align: center;
    color: var(--apt-muted);
    transition: color var(--apt-transition);
}
.apt-progress__num {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--apt-border-soft);
    color: var(--apt-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: .82rem;
    transition: var(--apt-transition);
    border: 2px solid transparent;
}
.apt-progress__label {
    font-size: .68rem;
    font-weight: 600;
    line-height: 1.2;
    max-width: 80px;
}
.apt-progress__dot.is-active { color: var(--apt-brand); }
.apt-progress__dot.is-active .apt-progress__num {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
    transform: scale(1.1);
    box-shadow: 0 8px 16px rgba(91, 95, 233, .35);
}
.apt-progress__dot.is-done { color: var(--apt-success); }
.apt-progress__dot.is-done .apt-progress__num {
    background: var(--apt-success-soft);
    color: var(--apt-success);
}
.apt-progress__dot.is-done .apt-progress__num::before {
    content: "\f00c"; /* check */
    font-family: "Font Awesome 6 Free", "Font Awesome 5 Free", FontAwesome;
    font-weight: 900;
}
.apt-progress__dot.is-done .apt-progress__num { font-size: 0; }
.apt-progress__dot.is-done .apt-progress__num::before { font-size: .78rem; }

/* ============================================================================
   Modal body & step containers
   ============================================================================ */
#bookingModal .modal-body,
.apt-modal__body {
    overflow-y: auto;
    flex: 1;
    background: var(--apt-surface);
    color: var(--apt-text);
    padding: 1.25rem 1.15rem calc(var(--apt-footer-h) + 1rem);
    -webkit-overflow-scrolling: touch;
}
.apt-modal__container { max-width: 600px; margin: 0 auto; }

/* Step animation — slide-in when becoming visible */
.step-content, .apt-step {
    animation: aptStepIn .35s cubic-bezier(.4, 0, .2, 1);
}
@keyframes aptStepIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: none; }
}

.booking-step { min-height: 200px; padding: 0; }

.apt-step__head { margin-bottom: 1.5rem; padding: 0 .25rem; }
.apt-step__title {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--apt-text);
    margin: 0 0 .35rem;
    letter-spacing: -.01em;
}
.apt-step__sub {
    font-size: .88rem;
    color: var(--apt-muted);
    margin: 0;
    line-height: 1.7;
}

/* ============================================================================
   Form fields (apt-field / apt-input)
   ============================================================================ */
.apt-field { margin-bottom: 1.4rem; display: flex; flex-direction: column; gap: .45rem; }
.apt-field__label {
    font-weight: 700;
    font-size: .9rem;
    color: var(--apt-text);
    margin: 0;
    display: flex;
    align-items: center;
    gap: .35rem;
}
.apt-field__optional { color: var(--apt-muted); font-weight: 500; font-size: .76rem; }
.apt-req { color: var(--apt-danger); font-weight: 700; }

.apt-input,
.custom-input-group,
.input-group-modern {
    display: flex;
    align-items: stretch;
    background: #fff;
    border: 1.5px solid var(--apt-border);
    border-radius: var(--apt-radius);
    padding: 0;
    box-shadow: var(--apt-shadow-sm);
    transition: border-color var(--apt-transition), box-shadow var(--apt-transition), background var(--apt-transition);
    margin-bottom: 0;
    overflow: hidden;
}
.apt-input:focus-within,
.custom-input-group:focus-within,
.input-group-modern:focus-within {
    border-color: var(--apt-brand);
    box-shadow: 0 0 0 4px rgba(91, 95, 233, .12);
}

.apt-input__icon,
.input-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    flex-shrink: 0;
    color: var(--apt-muted);
    font-size: 1rem;
    transition: color var(--apt-transition);
}
.apt-input:focus-within .apt-input__icon,
.apt-input:focus-within .input-icon { color: var(--apt-brand); }

.apt-input__field,
.form-input-clean,
.input-modern {
    flex: 1;
    min-width: 0;
    border: none !important;
    background: transparent !important;
    padding: .95rem 0 !important;
    font-family: inherit;
    font-size: .95rem !important;
    font-weight: 500;
    color: var(--apt-text) !important;
    outline: none !important;
    box-shadow: none !important;
    height: auto !important;
}
.apt-input__field::placeholder,
.form-input-clean::placeholder,
.input-modern::placeholder {
    color: var(--apt-muted);
    font-weight: 400;
}

.apt-input--with-action { padding-inline-start: .35rem; }
.apt-input__action,
.btn-input-action,
.btn-send-code {
    align-self: center;
    margin: .35rem;
    padding: .55rem 1rem;
    background: var(--apt-brand-soft);
    color: var(--apt-brand);
    border: none;
    border-radius: var(--apt-radius-sm);
    font-family: inherit;
    font-weight: 700;
    font-size: .8rem;
    cursor: pointer;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    transition: background var(--apt-transition), color var(--apt-transition), transform var(--apt-transition);
}
.apt-input__action:hover:not(:disabled),
.btn-input-action:hover:not(:disabled),
.btn-send-code:hover:not(:disabled) {
    background: var(--apt-brand);
    color: #fff;
    transform: translateY(-1px);
}
.apt-input__action:disabled,
.btn-input-action:disabled,
.btn-send-code:disabled {
    opacity: .6;
    cursor: not-allowed;
    background: var(--apt-border-soft);
    color: var(--apt-muted);
}

.apt-input--textarea { padding: .25rem; }
.apt-input--textarea .apt-input__field,
.apt-input--textarea textarea {
    padding: .85rem 1rem !important;
    resize: vertical;
    min-height: 90px;
    line-height: 1.75;
}

/* OTP-style numeric code input */
.apt-input--otp { padding: 0; }
.apt-input--otp .apt-input__field,
.apt-input--otp .form-input-clean,
.apt-input--otp .input-modern,
.apt-otp,
input.letter-spacing-2 {
    text-align: center !important;
    font-family: 'SF Mono', 'Menlo', 'Consolas', monospace;
    font-size: 1.3rem !important;
    font-weight: 700;
    letter-spacing: 10px;
    color: var(--apt-brand-dark) !important;
    direction: ltr !important;
    padding: 1rem 0 !important;
}
.apt-input--otp .apt-input__field::placeholder { letter-spacing: 6px; color: var(--apt-border); }
/* Hide number-input arrows */
.apt-otp::-webkit-outer-spin-button,
.apt-otp::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.apt-otp { -moz-appearance: textfield; }

.apt-hint {
    color: var(--apt-muted);
    font-size: .78rem;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    margin: 0;
}
.apt-hint i { color: var(--apt-brand); font-size: .8rem; }
.apt-hint--err { color: var(--apt-danger); }
.apt-hint--err i { color: var(--apt-danger); }

.apt-form-intro {
    color: var(--apt-muted);
    text-align: center;
    margin-bottom: 1.5rem;
    font-size: .88rem;
    line-height: 1.8;
}

/* ============================================================================
   Step 1 — Personnel
   ============================================================================ */
.apt-filter-bar {
    background: #fff;
    border: 1px solid var(--apt-border-soft);
    border-radius: var(--apt-radius);
    padding: .75rem;
    margin-bottom: 1.25rem;
    box-shadow: var(--apt-shadow-sm);
}
.apt-filter-chips,
#personnelJobFilter {
    display: flex;
    gap: .5rem;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: .15rem;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}
.apt-filter-chips::-webkit-scrollbar,
#personnelJobFilter::-webkit-scrollbar { height: 4px; }
.apt-filter-chips::-webkit-scrollbar-thumb,
#personnelJobFilter::-webkit-scrollbar-thumb { background: var(--apt-border); border-radius: 4px; }
.apt-filter-chips > *,
#personnelJobFilter > * {
    flex: 0 0 auto;
}
/* Apply chip styling to children regardless of tag (booking.js injects <button>/<a>/<span>) */
.apt-filter-chips > button,
.apt-filter-chips > a,
.apt-filter-chips > .badge,
#personnelJobFilter > button,
#personnelJobFilter > a,
#personnelJobFilter > .badge {
    padding: .5rem 1rem !important;
    background: var(--apt-surface) !important;
    color: var(--apt-text-soft) !important;
    border: 1px solid var(--apt-border) !important;
    border-radius: 999px !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    white-space: nowrap !important;
    cursor: pointer;
    transition: var(--apt-transition);
    text-decoration: none !important;
    margin: 0 !important;
}
.apt-filter-chips > .active,
.apt-filter-chips > .btn-primary,
.apt-filter-chips > .selected,
#personnelJobFilter > .active,
#personnelJobFilter > .btn-primary,
#personnelJobFilter > .selected {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark)) !important;
    color: #fff !important;
    border-color: var(--apt-brand) !important;
    box-shadow: 0 6px 16px rgba(91, 95, 233, .28);
}

.apt-doctor-list,
.personnel-list-container {
    max-height: none;
    overflow: visible;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .85rem;
}

/* booking.js builds cards with various class names; style them all consistently */
.doctor-card,
.personnel-card {
    background: #fff;
    border-radius: var(--apt-radius-lg);
    padding: 1.15rem;
    box-shadow: var(--apt-shadow-sm);
    border: 1.5px solid var(--apt-border-soft);
    transition: var(--apt-transition);
    position: relative;
    overflow: hidden;
    margin-bottom: 0;
    cursor: pointer;
    height: auto;
}
.doctor-card:hover,
.personnel-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--apt-shadow);
    border-color: var(--apt-brand-soft);
}
.doctor-card:active { transform: scale(.985); }

.doctor-card.selected,
.personnel-card.selected,
.personnel-card.border-success {
    border-color: var(--apt-brand) !important;
    background: linear-gradient(135deg, #fff, var(--apt-brand-mist));
    box-shadow: var(--apt-shadow) !important;
    transform: none;
}

.doctor-img,
.personnel-card .card-img-top {
    width: 80px;
    height: 80px;
    border-radius: var(--apt-radius);
    object-fit: cover;
    background: var(--apt-brand-mist);
    flex-shrink: 0;
    height: 130px !important;
}
.personnel-card .card-img-top { width: 100% !important; }
.personnel-card .card-body { padding: 1rem; color: var(--apt-text); }
.personnel-card .card-title { font-size: 1.02rem; font-weight: 800; margin-bottom: .35rem; color: var(--apt-text) !important; letter-spacing: -.01em; }
.personnel-card .card-text { font-size: .85rem; color: var(--apt-text-soft) !important; margin-bottom: .5rem; }
.personnel-card .specialties { font-size: .78rem; color: var(--apt-text-soft) !important; }
.personnel-card .specialties .badge {
    font-size: .7rem !important;
    padding: .25rem .6rem !important;
    margin: .15rem !important;
    background-color: var(--apt-brand-soft) !important;
    color: var(--apt-brand) !important;
    border-color: var(--apt-brand-soft) !important;
    border-radius: 999px !important;
    font-weight: 600;
}

.status-badge {
    font-size: .72rem;
    padding: .25rem .65rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-weight: 600;
}
.badge-online { background-color: var(--apt-success-soft); color: #065F46; }
.badge-verified { background-color: var(--apt-brand-soft); color: var(--apt-brand-dark); }

.btn-book-card {
    background: var(--apt-brand-soft);
    color: var(--apt-brand);
    border: none;
    border-radius: var(--apt-radius-sm);
    padding: .65rem 1rem;
    font-size: .85rem;
    font-weight: 700;
    width: 100%;
    margin-top: .85rem;
    transition: var(--apt-transition);
    cursor: pointer;
}
.btn-book-card:hover {
    background: var(--apt-brand);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(91, 95, 233, .25);
}

.selection-tick {
    position: absolute;
    top: 12px;
    inset-inline-start: 12px;
    font-size: 14px;
    color: #fff;
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    border-radius: 50%;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transform: scale(.5);
    transition: all .25s cubic-bezier(.175, .885, .32, 1.275);
    z-index: 10;
    box-shadow: 0 4px 10px rgba(91, 95, 233, .35);
}
.personnel-item.selected .selection-tick,
.personnel-card.selected .selection-tick { opacity: 1; transform: scale(1); }

.personnel-rating { display: flex; align-items: center; gap: .5rem; margin-top: .5rem; font-size: .85rem; }
.personnel-rating .stars { color: var(--apt-accent); }
.personnel-rating .rating-text { color: var(--apt-muted); font-size: .8rem; }
.first-free-time { margin-top: .5rem; padding: .25rem 0; }
.first-free-time small { color: var(--apt-info) !important; font-size: .78rem; }
.first-free-time i { margin-left: .25rem; }

.appointment-types { margin-bottom: .5rem; }
.appointment-type-badge {
    font-size: .72rem !important;
    padding: .3rem .65rem !important;
    margin: .15rem .15rem .15rem 0 !important;
    display: inline-flex !important;
    align-items: center;
    gap: .25rem;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: 999px !important;
}
.appointment-type-badge.badge-info { background-color: var(--apt-info) !important; border-color: var(--apt-info) !important; }
.appointment-type-badge.badge-success { background-color: var(--apt-success) !important; border-color: var(--apt-success) !important; }

.personnel-item.hidden { display: none !important; }
.personnel-item { display: block; }

.apt-loading {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--apt-muted);
}
.apt-loading__spinner {
    width: 56px;
    height: 56px;
    border: 4px solid var(--apt-border-soft);
    border-top-color: var(--apt-brand);
    border-radius: 50%;
    margin: 0 auto 1rem;
    animation: aptSpin .8s linear infinite;
}
@keyframes aptSpin { to { transform: rotate(360deg); } }
.apt-loading__text { font-size: .92rem; font-weight: 600; margin: 0; }

.apt-empty {
    margin: 0;
    padding: 1.25rem;
    background: var(--apt-brand-mist);
    border-radius: var(--apt-radius);
    color: var(--apt-muted);
    text-align: center;
    font-size: .9rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}
.apt-empty i { color: var(--apt-brand); }

/* ============================================================================
   Step 2 — Appointment-type cards, date picker, time slots, services
   ============================================================================ */
.apt-selected-personnel {
    display: flex;
    align-items: center;
    gap: .85rem;
    background: var(--apt-brand-soft) !important;
    color: var(--apt-brand-dark) !important;
    border: none !important;
    border-radius: var(--apt-radius);
    padding: .85rem 1rem;
    margin-bottom: 1.25rem;
}
.apt-selected-personnel > i {
    width: 38px;
    height: 38px;
    background: #fff;
    color: var(--apt-brand);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}
.apt-selected-personnel__label { display: block; font-size: .76rem; opacity: .8; }
.apt-selected-personnel strong { font-size: 1rem; }

/* Type cards */
.appointment-type-container,
.apt-type-grid {
    display: flex;
    gap: .75rem;
    margin-bottom: 1.4rem;
}
.type-option-card,
.apt-type {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #fff;
    border: 2px solid var(--apt-border);
    border-radius: var(--apt-radius-lg);
    padding: 1.15rem .75rem;
    cursor: pointer;
    transition: var(--apt-transition);
    height: 100%;
    box-shadow: var(--apt-shadow-sm);
    position: relative;
    overflow: hidden;
    text-align: center;
    margin: 0;
}
.type-option-card .icon-box,
.apt-type__icon {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: var(--apt-brand-mist);
    color: var(--apt-brand);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.45rem;
    margin-bottom: .75rem;
    transition: var(--apt-transition);
}
.type-option-card .type-title,
.apt-type__title {
    font-weight: 800;
    font-size: 1rem;
    color: var(--apt-text);
    margin-bottom: .2rem;
    display: block;
}
.type-option-card .type-desc,
.apt-type__desc {
    font-size: .76rem;
    color: var(--apt-muted);
    display: block;
    line-height: 1.5;
}
.apt-type__check {
    position: absolute;
    top: 10px;
    inset-inline-end: 10px;
    width: 22px;
    height: 22px;
    background: var(--apt-brand);
    color: #fff;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .65rem;
    opacity: 0;
    transform: scale(.5);
    transition: var(--apt-transition);
}
.btn-check:checked + .type-option-card,
.btn-check:checked + .apt-type {
    border-color: var(--apt-brand);
    background: linear-gradient(135deg, #fff, var(--apt-brand-mist));
    box-shadow: 0 14px 28px rgba(91, 95, 233, .18);
    transform: translateY(-2px);
}
.btn-check:checked + .type-option-card .icon-box,
.btn-check:checked + .apt-type .apt-type__icon {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
    box-shadow: 0 6px 14px rgba(91, 95, 233, .35);
}
.btn-check:checked + .type-option-card .type-title,
.btn-check:checked + .apt-type .apt-type__title { color: var(--apt-brand-dark); }
.btn-check:checked + .type-option-card .type-desc,
.btn-check:checked + .apt-type .apt-type__desc { color: var(--apt-brand); }
.btn-check:checked + .apt-type .apt-type__check { opacity: 1; transform: scale(1); }
.type-option-card:hover,
.apt-type:hover { border-color: var(--apt-brand-soft); }
.btn-check:checked + .type-option-card:hover,
.btn-check:checked + .apt-type:hover { border-color: var(--apt-brand); }

/* Date picker */
.date-selector-wrapper,
.apt-date-wrapper {
    position: relative;
    cursor: pointer;
    transition: var(--apt-transition);
}
.custom-date-input,
.apt-date-input {
    background-color: #fff !important;
    border: 1.5px solid var(--apt-border) !important;
    border-radius: var(--apt-radius) !important;
    height: 60px;
    text-align: center;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--apt-text);
    cursor: pointer;
    box-shadow: var(--apt-shadow-sm) !important;
    padding-right: 50px;
    transition: var(--apt-transition);
}
.custom-date-input::placeholder,
.apt-date-input::placeholder { color: var(--apt-muted); font-weight: 500; }
.custom-date-input:hover,
.apt-date-input:hover,
.date-selector-wrapper:hover .custom-date-input,
.apt-date-wrapper:hover .apt-date-input {
    border-color: var(--apt-brand) !important;
    background-color: var(--apt-brand-mist) !important;
}
.date-icon-overlay,
.apt-date-wrapper__icon {
    position: absolute;
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.3rem;
    color: var(--apt-brand);
    pointer-events: none;
    transition: color var(--apt-transition);
    width: 36px;
    height: 36px;
    background: var(--apt-brand-mist);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.date-selector-wrapper:hover .date-icon-overlay,
.apt-date-wrapper:hover .apt-date-wrapper__icon {
    background: var(--apt-brand);
    color: #fff;
}

/* Time slots */
.apt-time-slots,
#appointmentTimeSlots { display: flex; flex-direction: column; gap: .75rem; }

.time-chip {
    background: #fff;
    border: 1.5px solid var(--apt-border);
    color: var(--apt-text);
    border-radius: var(--apt-radius-sm);
    padding: .75rem .5rem;
    font-weight: 600;
    width: 100%;
    transition: var(--apt-transition);
    cursor: pointer;
    font-size: .9rem;
}
.time-chip:hover,
.time-chip.active {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
    border-color: var(--apt-brand);
    box-shadow: 0 8px 18px rgba(91, 95, 233, .28);
}

.time-slot-btn {
    user-select: none;
    border-radius: var(--apt-radius-sm) !important;
    padding: .6rem .85rem !important;
    font-weight: 600;
    transition: var(--apt-transition);
    border: 1.5px solid var(--apt-border) !important;
    background: #fff !important;
    color: var(--apt-text) !important;
}
.time-slot-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--apt-shadow-sm);
    border-color: var(--apt-brand) !important;
    color: var(--apt-brand) !important;
}
.time-slot-btn.active,
.time-slot-btn.btn-primary {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark)) !important;
    border-color: var(--apt-brand) !important;
    color: #fff !important;
    box-shadow: 0 8px 18px rgba(91, 95, 233, .28);
}
.time-slot-btn.active:hover {
    transform: translateY(-2px);
    filter: brightness(1.05);
}
.time-slot-btn.disabled,
.time-slot-btn:disabled {
    background-color: var(--apt-border-soft) !important;
    color: var(--apt-muted) !important;
    cursor: not-allowed !important;
    text-decoration: line-through;
    border-color: var(--apt-border) !important;
    opacity: .7;
    transform: none !important;
    box-shadow: none !important;
}
.time-slot-btn:disabled:hover { transform: none; box-shadow: none; }

/* Date cards (alternative rendering used in some JS branches) */
.date-card {
    background: #fff;
    border: 1.5px solid var(--apt-border);
    border-radius: var(--apt-radius);
    padding: .85rem .6rem;
    text-align: center;
    min-width: 80px;
    opacity: .7;
    transition: var(--apt-transition);
    cursor: pointer;
}
.date-card:hover { opacity: 1; border-color: var(--apt-brand); }
.date-card.active {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
    opacity: 1;
    box-shadow: 0 10px 22px rgba(91, 95, 233, .35);
    border-color: var(--apt-brand);
}

/* Shift rows */
.shift-row { padding-bottom: 1rem; border-bottom: 1px dashed var(--apt-border-soft); margin-bottom: 1rem; }
.shift-row:last-child { border-bottom: none !important; padding-bottom: 0 !important; margin-bottom: 0; }
.shift-header { margin-bottom: .65rem; font-weight: 700; color: var(--apt-text-soft); font-size: .85rem; }
.shift-slots { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: .5rem; margin-top: .35rem; }

/* Services */
.apt-service-list,
#appointmentServiceList {
    display: flex;
    flex-direction: column;
    gap: .55rem;
}

/* ============================================================================
   Step 3 — Visitor info: upload zone & attachment previews
   ============================================================================ */
.upload-zone,
.apt-upload {
    border: 2px dashed var(--apt-border);
    border-radius: var(--apt-radius-lg);
    background: var(--apt-card);
    padding: 1.85rem 1.25rem;
    text-align: center;
    cursor: pointer;
    transition: var(--apt-transition);
}
.upload-zone:hover,
.apt-upload:hover {
    border-color: var(--apt-brand);
    background: var(--apt-brand-mist);
    transform: translateY(-1px);
}
.apt-upload__icon {
    width: 52px;
    height: 52px;
    margin: 0 auto .75rem;
    background: var(--apt-brand-mist);
    color: var(--apt-brand);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    transition: var(--apt-transition);
}
.apt-upload:hover .apt-upload__icon {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
}
.apt-upload__title { display: block; font-weight: 700; color: var(--apt-text); font-size: .92rem; margin-bottom: .25rem; }
.apt-upload__desc { color: var(--apt-muted); font-size: .8rem; }

.apt-upload__previews,
#attachmentPreviews {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 1rem;
    justify-content: center;
}
.attachment-preview-item {
    position: relative;
    width: 96px;
    height: 96px;
    border: 1.5px solid var(--apt-border);
    border-radius: var(--apt-radius-sm);
    overflow: hidden;
    background: var(--apt-surface);
}
.attachment-preview-item img { width: 100%; height: 100%; object-fit: cover; }
.remove-attachment-btn {
    position: absolute;
    top: 4px;
    right: 4px;
    background: var(--apt-danger);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 24px;
    height: 24px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 700;
    line-height: 1;
    padding: 0;
    box-shadow: 0 4px 10px rgba(239, 68, 68, .35);
    transition: var(--apt-transition);
}
.remove-attachment-btn:hover { background: #DC2626; transform: scale(1.1); }
.remove-attachment-btn:active { background: #B91C1C; }

/* ============================================================================
   Step 4 — Receipt/ticket card
   ============================================================================ */
.ticket-card,
.apt-ticket {
    border-radius: var(--apt-radius-xl) !important;
    background-color: #fff !important;
    overflow: hidden !important;
    position: relative;
    box-shadow: var(--apt-shadow) !important;
    border: 1px solid var(--apt-border-soft);
}
.ticket-top-accent,
.apt-ticket__accent {
    height: 6px;
    background: linear-gradient(90deg, var(--apt-brand), var(--apt-accent));
    width: 100%;
}
.apt-ticket__hero { text-align: center; margin-bottom: 1.5rem; }
.success-icon-box,
.apt-ticket__icon {
    width: 78px;
    height: 78px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--apt-brand-mist), var(--apt-brand-soft));
    border: 4px solid #fff;
    box-shadow: 0 0 0 4px var(--apt-brand-mist);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--apt-brand);
    font-size: 2.1rem;
    margin: 0 auto 1rem;
}
.apt-ticket__title {
    font-weight: 800;
    font-size: 1.15rem;
    color: var(--apt-text);
    margin: 0 0 .35rem;
    letter-spacing: -.01em;
}
.apt-ticket__sub { color: var(--apt-muted); font-size: .85rem; }

.apt-ticket__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}
.apt-ticket__label { color: var(--apt-muted); font-size: .85rem; }
.apt-ticket__value { text-align: end; }
.apt-ticket__value-main { display: block; font-weight: 800; color: var(--apt-text); font-size: .98rem; }
.apt-ticket__value-meta { display: block; color: var(--apt-info); font-size: .78rem; margin-top: .15rem; }

.dotted-line,
.apt-ticket__divider {
    border-top: 2px dashed var(--apt-border);
    width: 100%;
    opacity: .8;
    margin: 1.15rem 0;
}

.price-box,
.apt-ticket__price {
    background: linear-gradient(135deg, var(--apt-brand-mist), var(--apt-brand-soft));
    border: 1px solid var(--apt-brand-soft);
    border-radius: var(--apt-radius);
    padding: 1.1rem 1.25rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 1.25rem;
}
.price-box .text-primary,
.apt-ticket__price-value {
    color: var(--apt-brand-dark) !important;
    font-weight: 900 !important;
    font-size: 1.3rem !important;
    letter-spacing: -.01em;
}
.apt-ticket__price-label { color: var(--apt-text-soft); font-size: .9rem; font-weight: 600; }

.receipt-card { background: white; border-radius: var(--apt-radius-xl); overflow: hidden; box-shadow: var(--apt-shadow); position: relative; }
.receipt-header { background: var(--apt-text); color: #fff; padding: 2rem 1.25rem; text-align: center; position: relative; }
.receipt-jagged {
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 10px;
    background: white;
    clip-path: polygon(0% 0%, 2% 100%, 4% 0%, 6% 100%, 8% 0%, 10% 100%, 12% 0%, 14% 100%, 16% 0%, 18% 100%, 20% 0%, 22% 100%, 24% 0%, 26% 100%, 28% 0%, 30% 100%, 32% 0%, 34% 100%, 36% 0%, 38% 100%, 40% 0%, 42% 100%, 44% 0%, 46% 100%, 48% 0%, 50% 100%, 52% 0%, 54% 100%, 56% 0%, 58% 100%, 60% 0%, 62% 100%, 64% 0%, 66% 100%, 68% 0%, 70% 100%, 72% 0%, 74% 100%, 76% 0%, 78% 100%, 80% 0%, 82% 100%, 84% 0%, 86% 100%, 88% 0%, 90% 100%, 92% 0%, 94% 100%, 96% 0%, 98% 100%, 100% 0%);
}

/* ============================================================================
   Sticky footer + CTA buttons
   ============================================================================ */
.footer-cta,
.apt-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding: .85rem 1rem calc(.85rem + var(--apt-safe-b));
    background: rgba(255, 255, 255, .96);
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-top: 1px solid var(--apt-border-soft);
    z-index: 1030;
    box-shadow: 0 -8px 24px rgba(15, 23, 42, .06);
}
@media (min-width: 768px) {
    /* Inside the centred-dialog mode, anchor the footer to the modal-content */
    .footer-cta, .apt-footer { position: sticky; bottom: 0; }
}
.apt-footer__inner { max-width: 600px; margin: 0 auto; }

.apt-btn-cta,
#nextStepBtn,
#submitBookingBtn,
#proceedToPaymentBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    width: 100%;
    padding: 1rem 1.25rem !important;
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark)) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--apt-radius-lg) !important;
    font-weight: 800;
    font-size: 1rem;
    cursor: pointer;
    transition: transform var(--apt-transition), box-shadow var(--apt-transition), filter var(--apt-transition);
    box-shadow: 0 14px 28px rgba(91, 95, 233, .30);
    line-height: 1;
    text-decoration: none;
}
.apt-btn-cta:hover:not(:disabled),
#nextStepBtn:hover:not(:disabled),
#submitBookingBtn:hover:not(:disabled),
#proceedToPaymentBtn:hover:not(:disabled) {
    transform: translateY(-2px);
    filter: brightness(1.05);
    box-shadow: 0 20px 38px rgba(91, 95, 233, .38);
}
.apt-btn-cta:active { transform: translateY(0); }
.apt-btn-cta:disabled { opacity: .65; cursor: not-allowed; filter: grayscale(.3); }

/* booking.js swaps `btn-primary` ↔ `btn-success` on #nextStepBtn between steps */
#nextStepBtn.btn-success,
.btn.btn-success.apt-btn-cta {
    background: linear-gradient(135deg, var(--apt-success), #059669) !important;
    box-shadow: 0 14px 28px rgba(16, 185, 129, .30);
}
#nextStepBtn.btn-success:hover {
    box-shadow: 0 20px 38px rgba(16, 185, 129, .38);
}

.apt-btn-cta--pay { background: linear-gradient(135deg, #059669, var(--apt-success)) !important; box-shadow: 0 14px 28px rgba(16, 185, 129, .30) !important; }
.apt-btn-cta--pay:hover { box-shadow: 0 20px 38px rgba(16, 185, 129, .38) !important; }

.apt-btn-cta--sm { padding: .7rem 1.2rem !important; font-size: .9rem; width: auto; box-shadow: 0 10px 22px rgba(91, 95, 233, .25); }

.apt-btn-cta__arrow {
    font-size: .85rem;
    margin-inline-start: auto;
    transition: transform var(--apt-transition);
}
.apt-btn-cta:hover .apt-btn-cta__arrow { transform: translateX(-4px); }

.apt-btn-ghost,
.btn.btn-light.apt-btn-ghost,
.btn.btn-secondary.apt-btn-ghost {
    background: transparent;
    color: var(--apt-muted);
    border: none;
    font-weight: 600;
    padding: .65rem 1.25rem;
    border-radius: var(--apt-radius);
    transition: var(--apt-transition);
}
.apt-btn-ghost:hover { color: var(--apt-text); background: var(--apt-surface); }
.apt-btn-ghost-text,
.btn-text-cancel {
    color: var(--apt-muted);
    background: transparent;
    border: none;
    font-size: .88rem;
    margin-top: 1rem;
    padding: .5rem;
    cursor: pointer;
    transition: color var(--apt-transition);
}
.apt-btn-ghost-text:hover,
.btn-text-cancel:hover { color: var(--apt-text); }

.btn-pay-action {
    background-color: var(--apt-success);
    border: none;
    transition: var(--apt-transition);
}
.btn-pay-action:hover {
    background-color: #059669;
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(16, 185, 129, .30);
}

.btn-submit-modern {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
    border: none;
    height: 54px;
    border-radius: var(--apt-radius);
    font-size: 1rem;
    font-weight: 800;
    letter-spacing: .3px;
    box-shadow: 0 12px 26px rgba(91, 95, 233, .28);
    transition: var(--apt-transition);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
}
.btn-submit-modern:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 36px rgba(91, 95, 233, .36);
    color: #fff;
}

/* ============================================================================
   Generic Bootstrap overrides scoped to booking modal
   ============================================================================ */
#bookingModal .modal-content { color: var(--apt-text); }
#bookingModal .modal-body h4 { color: var(--apt-text) !important; margin-bottom: 1.5rem; }
#bookingModal .form-control { color: var(--apt-text); background-color: #fff; }
#bookingModal .form-control:focus { color: var(--apt-text); background-color: #fff; }

/* Force placeholder backdrop blur to look proper */
.modal-backdrop.show { backdrop-filter: blur(5px); opacity: .55; }

/* Bootstrap's date-picker popover sometimes injects an `input-group`; preserve its behaviour */
.input-group > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
    margin-left: -1px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: unset;
    border-bottom-left-radius: unset;
}

/* ============================================================================
   Status / Comments / Add-comment / Rating modals
   ============================================================================ */
#statusModal {
    background-color: rgba(15, 23, 42, .65) !important;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 100001 !important;
}
#statusModal .modal-dialog { z-index: 100001; }
.apt-status-modal .modal-content,
.apt-status-card {
    border: none !important;
    border-radius: var(--apt-radius-xl) !important;
    overflow: hidden;
    box-shadow: var(--apt-shadow-lg);
    background: #fff;
}
.apt-status-icon {
    font-size: 3.5rem;
    color: var(--apt-brand);
    margin: 0 0 1rem;
}
.apt-status-icon i { animation: aptPopIn .5s cubic-bezier(.175, .885, .32, 1.275); }
@keyframes aptPopIn { 0% { transform: scale(0); opacity: 0; } 100% { transform: scale(1); opacity: 1; } }
#statusIcon i { animation: aptPopIn .5s cubic-bezier(.175, .885, .32, 1.275); }

.apt-status-title {
    font-weight: 800;
    color: var(--apt-text);
    margin-bottom: .5rem;
    font-size: 1.15rem;
    letter-spacing: -.01em;
}
.apt-status-message { color: var(--apt-muted); font-size: .92rem; line-height: 1.7; margin-bottom: 1.5rem; }
.apt-status-btn { width: 100%; }

/* Side modals (comments / add-comment / rating) */
#commentsModal, #addCommentModal, #ratingModal {
    background-color: rgba(15, 23, 42, .55) !important;
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    z-index: 100000 !important;
}
#commentsModal .modal-dialog,
#addCommentModal .modal-dialog,
#ratingModal .modal-dialog { z-index: 100001; }

.modern-modal-content,
.apt-modern-card {
    border: none !important;
    border-radius: var(--apt-radius-xl) !important;
    box-shadow: var(--apt-shadow-lg);
    overflow: hidden;
    background: #fff;
    color: var(--apt-text);
}
.modern-modal-header,
.apt-modern-card__header {
    background: linear-gradient(135deg, var(--apt-brand-mist), #fff);
    border-bottom: 1px solid var(--apt-border-soft);
    padding: 1.15rem 1.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.modal-header .btn-close { padding: .5rem; margin: unset; }
.modern-modal-title,
.apt-modern-card__title {
    font-weight: 800 !important;
    color: var(--apt-text) !important;
    font-size: 1.05rem !important;
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
}
.modern-modal-title i,
.apt-modern-card__title i { color: var(--apt-brand); }

.apt-modern-card__footer,
#commentsModal .modal-footer,
#ratingModal .modal-footer {
    border-top: 1px solid var(--apt-border-soft);
    padding: 1rem 1.25rem;
    background: #fff;
    display: flex;
    gap: .75rem;
    justify-content: space-between;
    align-items: center;
}
.apt-modern-card__body--soft { background: var(--apt-surface); }

/* Comments list */
.comments-scroll-container,
.apt-comments {
    max-height: 500px;
    overflow-y: auto;
    padding: 1rem 1.25rem;
    background: var(--apt-surface);
}

.modern-comment-card {
    background: #fff;
    border: 1px solid var(--apt-border-soft);
    border-radius: var(--apt-radius-lg);
    padding: 1.15rem;
    margin-bottom: .85rem;
    box-shadow: var(--apt-shadow-sm);
    transition: var(--apt-transition);
}
.modern-comment-card:hover { box-shadow: var(--apt-shadow); transform: translateY(-2px); }
.comment-header { display: flex; align-items: center; margin-bottom: .85rem; gap: .75rem; }
.comment-avatar {
    width: 48px;
    height: 48px;
    background: var(--apt-brand-mist);
    color: var(--apt-brand);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    flex-shrink: 0;
}
.comment-user-info { flex-grow: 1; }
.comment-author-name { font-weight: 800; color: var(--apt-text); font-size: .98rem; display: block; }
.comment-date { font-size: .76rem; color: var(--apt-muted); display: block; margin-top: .15rem; }
.comment-stars {
    background: #FFFBEB;
    padding: .25rem .6rem;
    border-radius: 8px;
    border: 1px solid #FEF3C7;
    white-space: nowrap;
}
.star-filled { color: var(--apt-accent); font-size: .9rem; }
.star-empty { color: var(--apt-border); font-size: .9rem; }
.comment-text {
    color: var(--apt-text-soft);
    line-height: 1.8;
    font-size: .92rem;
    margin-top: .75rem;
    background: var(--apt-surface);
    padding: .85rem 1rem;
    border-radius: var(--apt-radius);
    border-inline-start: 3px solid var(--apt-brand-soft);
}
/* Fallback for booking.js's older `.comment-item` rendering */
.comment-item {
    background: #fff;
    border: 1px solid var(--apt-border-soft) !important;
    padding: 1rem;
    margin-bottom: .85rem;
    border-radius: var(--apt-radius);
    box-shadow: var(--apt-shadow-sm);
}
.comment-item .stars { font-size: .9rem; color: var(--apt-accent); }
.comment-item strong { color: var(--apt-text); }
.comment-item p { color: var(--apt-text-soft); margin-top: .5rem; }

/* Appointment-list cards in add-comment step 2 */
.appointment-list-container,
.apt-appointment-list {
    max-height: 400px;
    overflow-y: auto;
    padding: .25rem;
    display: flex;
    flex-direction: column;
    gap: .85rem;
}
.appointment-card {
    background: #fff;
    border: 1.5px solid var(--apt-border-soft);
    border-radius: var(--apt-radius-lg);
    padding: 1rem 1.15rem;
    box-shadow: var(--apt-shadow-sm);
    transition: var(--apt-transition);
    display: flex;
    flex-direction: column;
    gap: .75rem;
}
.appointment-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--apt-shadow);
    border-color: var(--apt-brand);
}
.app-card-header { display: flex; justify-content: space-between; align-items: flex-start; gap: .5rem; }
.app-personnel-name { font-weight: 800; font-size: 1.05rem; color: var(--apt-text); margin: 0; line-height: 1.4; }
.app-date-badge {
    background: var(--apt-surface);
    color: var(--apt-muted);
    border: 1px solid var(--apt-border);
    padding: .35rem .7rem;
    border-radius: 999px;
    font-size: .76rem;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    white-space: nowrap;
}
.app-status-row { display: flex; gap: .35rem; flex-wrap: wrap; }
.status-pill {
    font-size: .7rem;
    padding: .25rem .65rem;
    border-radius: 999px;
    font-weight: 700;
}
.status-visited { background: var(--apt-success-soft); color: #065F46; }
.status-rated { background: var(--apt-brand-soft); color: var(--apt-brand-dark); }

.btn-action-card {
    width: 100%;
    border-radius: var(--apt-radius-sm);
    padding: .65rem;
    font-weight: 700;
    font-size: .9rem;
    transition: var(--apt-transition);
    border: none;
    cursor: pointer;
}
.btn-rate-new { background: var(--apt-brand-soft); color: var(--apt-brand); }
.btn-rate-new:hover { background: var(--apt-brand); color: #fff; }
.btn-rate-edit { background: #FFFBEB; color: #B45309; }
.btn-rate-edit:hover { background: var(--apt-accent); color: #fff; }

.appointment-item-for-rating {
    border: 1px solid var(--apt-border);
    border-radius: var(--apt-radius);
    padding: 1rem;
    margin-bottom: .65rem;
    background: var(--apt-surface);
    transition: var(--apt-transition);
}
.appointment-item-for-rating:hover { background: #fff; border-color: var(--apt-brand); box-shadow: var(--apt-shadow-sm); }

/* Rating stars */
.apt-rating-info {
    background: var(--apt-brand-soft) !important;
    color: var(--apt-brand-dark) !important;
    border: none !important;
    border-radius: var(--apt-radius) !important;
    padding: .75rem 1rem !important;
    font-size: .9rem;
}
.rating-stars,
.apt-rating-stars {
    font-size: 2rem;
    color: var(--apt-accent);
    cursor: pointer;
    display: flex;
    gap: .35rem;
    justify-content: center;
    padding: .85rem;
    background: #FFFBEB;
    border-radius: var(--apt-radius);
}
.rating-stars .fa-star,
.apt-rating-stars .fa-star {
    margin: 0;
    transition: transform var(--apt-transition), color var(--apt-transition);
}
.rating-stars .fa-star:hover,
.apt-rating-stars .fa-star:hover { transform: scale(1.2); }

/* Legacy text-muted/info overrides ─ kept for older booking.js renderings */
#commentsModal .text-muted, #commentsModal .text-info { font-size: .82rem; }
.badge {
    background-color: var(--apt-brand-soft);
    color: var(--apt-brand-dark);
    margin-right: 5px;
    border-radius: 999px;
}

/* ============================================================================
   Responsive — extra polish for small screens & hardware-back-button UX
   ============================================================================ */

/* Floating launch button: stack icon on smaller screens isn't needed (pill works) */
@media (max-width: 576px) {
    .apt-launch { padding: .85rem 1.25rem .85rem 1rem; font-size: .92rem; }
    .apt-launch__icon { width: 28px; height: 28px; font-size: .85rem; }

    .apt-progress { padding: .85rem 1rem .65rem; }
    .apt-progress__label { font-size: 0; max-width: 0; }
    .apt-progress__num { width: 26px; height: 26px; font-size: .78rem; }
    .apt-progress__dots { gap: .25rem; }

    .apt-step__title { font-size: 1.1rem; }
    .appointment-type-container, .apt-type-grid { gap: .5rem; }
    .type-option-card, .apt-type { padding: .85rem .5rem; }
    .type-option-card .icon-box, .apt-type__icon { width: 44px; height: 44px; font-size: 1.15rem; }
    .type-option-card .type-title, .apt-type__title { font-size: .9rem; }
    .type-option-card .type-desc, .apt-type__desc { font-size: .7rem; }

    .custom-date-input, .apt-date-input { height: 54px; font-size: .98rem; padding-right: 44px; }
    .date-icon-overlay, .apt-date-wrapper__icon { right: 12px; width: 32px; height: 32px; font-size: 1.1rem; }

    .shift-slots { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
    .time-slot-btn { padding: .55rem .55rem !important; font-size: .82rem; }

    .modal-header, .apt-modal__header { padding: .75rem .9rem; min-height: 56px; }
    .apt-modal__title { font-size: .92rem; }
    .apt-back-btn { padding: .4rem .65rem; font-size: .76rem; }

    .ticket-card .card-body { padding: 1.25rem !important; }
    .apt-ticket__icon { width: 64px; height: 64px; font-size: 1.65rem; }
    .price-box, .apt-ticket__price { padding: .85rem 1rem; }
    .apt-ticket__price-value { font-size: 1.15rem !important; }

    .footer-cta, .apt-footer { padding: .65rem .85rem calc(.65rem + var(--apt-safe-b)); }
    .apt-btn-cta { padding: .85rem 1rem !important; font-size: .95rem; }
}

/* iOS notch / Android nav-bar friendly */
@supports (padding: max(0px)) {
    .apt-footer,
    .footer-cta {
        padding-bottom: max(calc(.85rem + var(--apt-safe-b)), env(safe-area-inset-bottom));
    }
}

/* Disable hover-induced lifts on touch devices to avoid sticky-hover artefacts */
@media (hover: none) {
    .apt-launch:hover,
    .doctor-card:hover,
    .personnel-card:hover,
    .time-slot-btn:hover,
    .apt-btn-cta:hover {
        transform: none;
    }
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
    .apt-launch, .doctor-card, .personnel-card, .time-slot-btn, .apt-btn-cta,
    .step-content, .apt-step, .apt-progress__fill, .apt-progress__num,
    .modern-comment-card, .appointment-card,
    .apt-status-icon i, #statusIcon i {
        animation: none !important;
        transition: none !important;
    }
}

/* ============================================================================
   UX ENHANCEMENT LAYER — styles for additions in Index.cshtml's enhancement
   script. Keep these visually consistent with the rest of the widget.
   ============================================================================ */

/* ── Inline field errors (under input, replaces some modal popups) ───────── */
.apt-inline-err {
    margin-top: .5rem;
    padding: .55rem .85rem;
    background: #FEF2F2;
    color: #B91C1C;
    border: 1px solid #FECACA;
    border-radius: var(--apt-radius-sm);
    font-size: .82rem;
    font-weight: 600;
    line-height: 1.5;
    display: none;
    align-items: center;
    gap: .45rem;
    animation: aptErrIn .25s ease-out;
}
.apt-inline-err.is-visible { display: inline-flex; }
.apt-inline-err i { font-size: .9rem; flex-shrink: 0; }
@keyframes aptErrIn {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: none; }
}
/* Highlight the field when an error is visible */
.apt-field:has(.apt-inline-err.is-visible) .apt-input,
.apt-field:has(.apt-inline-err.is-visible) .custom-input-group,
.apt-field:has(.apt-inline-err.is-visible) .input-group-modern {
    border-color: #FCA5A5;
    box-shadow: 0 0 0 4px rgba(239, 68, 68, .12);
}

/* ── Success hint (e.g. "code sent to 0912…") ───────────────────────────── */
.apt-hint--success {
    color: #047857 !important;
    background: #ECFDF5;
    padding: .55rem .85rem;
    border-radius: var(--apt-radius-sm);
    border: 1px solid #A7F3D0;
    display: inline-flex !important;
    align-items: center;
    gap: .45rem;
    margin-top: .35rem;
    font-size: .82rem;
    line-height: 1.55;
}
.apt-hint--success i { color: #10B981 !important; }
#aptCodeSentTo { font-weight: 800; }
#aptCodeResendInfo { color: var(--apt-text-soft); margin-inline-start: .35rem; }

/* ── Send-code button cooldown state ────────────────────────────────────── */
#aptSendCodeBtn.is-cooling {
    background: var(--apt-border-soft) !important;
    color: var(--apt-muted) !important;
    cursor: progress;
    position: relative;
    overflow: hidden;
}
#aptSendCodeBtn.is-cooling::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(91, 95, 233, .15), transparent);
    animation: aptShimmer 1.4s ease-in-out infinite;
}
@keyframes aptShimmer {
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* ── Loading state on submit / payment buttons ──────────────────────────── */
.apt-btn-cta.is-loading,
#submitBookingBtn.is-loading,
#proceedToPaymentBtn.is-loading {
    cursor: progress !important;
    opacity: .85 !important;
    filter: saturate(.85);
    pointer-events: none;
}
.apt-btn-cta.is-loading .spinner-border,
#submitBookingBtn.is-loading .spinner-border,
#proceedToPaymentBtn.is-loading .spinner-border {
    margin-inline-end: .35rem;
}

/* ── Edit pencils on step-4 ticket rows ────────────────────────────────── */
.apt-ticket__row--editable {
    position: relative;
    padding-inline-end: 2.5rem;
}
.apt-ticket__edit {
    position: absolute;
    /* Sit on the END side (left in RTL) — the same side reserved by the row's
       padding-inline-end. Using inset-inline-START put the pencil on the START
       side (right in RTL), on top of the label, which hid the row titles. */
    inset-inline-end: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--apt-brand-soft);
    color: var(--apt-brand);
    border: none;
    border-radius: 10px;
    cursor: pointer;
    font-size: .82rem;
    transition: var(--apt-transition);
}
.apt-ticket__edit:hover {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
    transform: translateY(-50%) scale(1.08);
    box-shadow: 0 8px 16px rgba(91, 95, 233, .28);
}
.apt-ticket__edit:focus-visible {
    outline: 2px solid var(--apt-brand);
    outline-offset: 2px;
}

.apt-ticket__weekday {
    display: inline-block !important;
    margin-top: .25rem;
    padding: .15rem .55rem;
    background: var(--apt-brand-soft);
    color: var(--apt-brand-dark) !important;
    border-radius: 999px;
    font-size: .72rem !important;
    font-weight: 700;
}

/* ── Quick-date chips (above the Persian date picker on step 2) ────────── */
.apt-quick-dates {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: .85rem;
}
.apt-quick-date {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .55rem 1rem;
    background: var(--apt-card);
    color: var(--apt-text-soft);
    border: 1.5px solid var(--apt-border);
    border-radius: 999px;
    font-family: inherit;
    font-weight: 600;
    font-size: .85rem;
    cursor: pointer;
    transition: var(--apt-transition);
    white-space: nowrap;
    box-shadow: var(--apt-shadow-sm);
}
.apt-quick-date i { color: var(--apt-brand); font-size: .75rem; transition: color var(--apt-transition); }
.apt-quick-date:hover {
    border-color: var(--apt-brand);
    color: var(--apt-brand-dark);
    transform: translateY(-1px);
}
.apt-quick-date.is-active {
    background: linear-gradient(135deg, var(--apt-brand), var(--apt-brand-dark));
    color: #fff;
    border-color: var(--apt-brand);
    box-shadow: 0 8px 18px rgba(91, 95, 233, .28);
}
.apt-quick-date.is-active i { color: rgba(255, 255, 255, .9); }

/* ── Misc microcopy/help styles ─────────────────────────────────────────── */
.apt-time-hint {
    margin-top: .65rem;
    background: var(--apt-brand-mist);
    padding: .55rem .85rem;
    border-radius: var(--apt-radius-sm);
    color: var(--apt-text-soft) !important;
    font-size: .78rem;
    display: inline-flex !important;
    align-items: center;
    gap: .35rem;
}
.apt-time-hint i { color: var(--apt-accent); }

/* When any time slot exists, show the hint */
#appointmentTimeSlots:not(:empty) ~ .apt-time-hint { display: inline-flex !important; }

/* Phone field shown valid (10/11 digits) — subtle green tick via :valid */
#visitorPhone:valid + .apt-input__action:not(.is-cooling) {
    background: linear-gradient(135deg, var(--apt-success), #059669);
    color: #fff;
}

/* Mobile-only: extra bottom safety so sticky footer never overlaps last field */
@media (max-width: 768px) {
    .apt-ticket__edit { width: 30px; height: 30px; }
    .apt-quick-date { padding: .5rem .85rem; font-size: .8rem; }
    .apt-inline-err { font-size: .78rem; padding: .5rem .75rem; }
}

/* Keyboard-friendly focus rings */
.apt-quick-date:focus-visible,
.apt-ticket__edit:focus-visible,
#aptSendCodeBtn:focus-visible {
    outline: 2px solid var(--apt-brand);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .apt-inline-err, #aptSendCodeBtn.is-cooling::after, .apt-quick-date {
        animation: none !important;
        transition: none !important;
    }
}
