/* ═══════════════════════════════════════════════════════════════════════════
   PM Booking – Frontend CSS
   Prefix: pmb-  (žádná kolize s tématem nebo WP)
═══════════════════════════════════════════════════════════════════════════ */

/* ── Design tokeny ─────────────────────────────────────────────────────── */
.pm-booking-wrap {
    --pmb-bg-page:        #0A0A0A;
    --pmb-bg-surface:     #141414;
    --pmb-bg-card:        #1A1A1A;
    --pmb-border:         #2A2520;
    --pmb-gold:           #C9A962;
    --pmb-gold-dim:       rgba(201, 169, 98, 0.25);
    --pmb-text-primary:   #F5F0E8;
    --pmb-text-secondary: #A09888;
    --pmb-text-muted:     #6A6058;
    --pmb-error:          #E5484D;
    --pmb-success:        #46A758;
    --pmb-radius:         4px;

    color: var(--pmb-text-primary);
    max-width: 860px;
    margin: 0 auto;
    font-size: 15px;
    line-height: 1.5;
}

/* ── Honeypot ────────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-hp {
    position: absolute;
    left: -9999px;
    top: -9999px;
    opacity: 0;
    pointer-events: none;
    tab-index: -1;
}

/* ── Auth section ────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-auth-section {
    background: var(--pmb-bg-surface);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    padding: 40px;
    margin-bottom: 24px;
}

/* ── Generic section card ────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-section {
    background: var(--pmb-bg-card);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    padding: 32px;
    margin-bottom: 24px;
}

/* ── Tabs ────────────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-tabs {
    display: flex;
    border-bottom: 1px solid var(--pmb-border);
    margin-bottom: 28px;
}

.pm-booking-wrap .pmb-tab {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--pmb-text-muted);
    font-size: 14px;
    font-weight: 500;
    padding: 14px 0;
    margin-right: 32px;
    margin-bottom: -1px;
    cursor: pointer;
    transition: color 0.2s, border-color 0.2s;
    font-family: inherit;
}

.pm-booking-wrap .pmb-tab:hover {
    color: var(--pmb-text-primary);
}

.pm-booking-wrap .pmb-tab--active {
    color: var(--pmb-text-primary);
    border-bottom-color: var(--pmb-gold);
}

.pm-booking-wrap .pmb-tab-panel--hidden {
    display: none !important;
}

/* ── Form layout ─────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Two-column row for paired fields */
.pm-booking-wrap .pmb-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.pm-booking-wrap .pmb-form__group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pm-booking-wrap .pmb-form__group--full {
    grid-column: 1 / -1;
}

.pm-booking-wrap .pmb-form__label {
    font-size: 12px;
    color: var(--pmb-text-secondary);
    font-weight: 400;
}

/* Action row — centered inline buttons */
.pm-booking-wrap .pmb-form__actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
    padding-top: 4px;
}

.pm-booking-wrap .pmb-form__actions--col {
    flex-direction: column;
    gap: 12px;
}

/* ── Inputs — high specificity to override theme ─────────────────────────── */
.pm-booking-wrap input.pmb-form__input,
.pm-booking-wrap select.pmb-form__select,
.pm-booking-wrap textarea.pmb-form__textarea {
    background-color: var(--pmb-bg-page) !important;
    border: 1px solid var(--pmb-border) !important;
    border-radius: var(--pmb-radius) !important;
    color: var(--pmb-text-primary) !important;
    font-size: 16px !important;
    font-weight: 300 !important;
    padding: 14px 16px !important;
    outline: none !important;
    box-shadow: none !important;
    width: 100%;
    box-sizing: border-box;
    font-family: inherit;
    transition: border-color 0.2s;
    -webkit-appearance: none;
    appearance: none;
}

.pm-booking-wrap input.pmb-form__input:focus,
.pm-booking-wrap select.pmb-form__select:focus,
.pm-booking-wrap textarea.pmb-form__textarea:focus {
    border-color: var(--pmb-gold) !important;
    box-shadow: none !important;
    outline: none !important;
}

.pm-booking-wrap input.pmb-form__input::placeholder,
.pm-booking-wrap textarea.pmb-form__textarea::placeholder {
    color: var(--pmb-text-muted) !important;
    font-weight: 300;
}

.pm-booking-wrap textarea.pmb-form__textarea {
    resize: vertical;
    min-height: 80px;
    line-height: 1.5;
}

.pm-booking-wrap select.pmb-form__select {
    cursor: pointer;
}

.pm-booking-wrap select.pmb-form__select option {
    background: var(--pmb-bg-page);
    color: var(--pmb-text-primary);
}

.pm-booking-wrap input.pmb-form__input--error,
.pm-booking-wrap select.pmb-form__select--error {
    border-color: var(--pmb-error) !important;
}

.pm-booking-wrap .pmb-hint {
    font-size: 11px;
    color: var(--pmb-text-muted);
    font-weight: 400;
}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 32px;
    border-radius: var(--pmb-radius);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background 0.2s, color 0.2s, border-color 0.2s, opacity 0.2s;
    text-decoration: none;
    white-space: nowrap;
    font-family: inherit;
    line-height: 1;
    width: auto;
}

/* Outline (gold) — main CTA */
.pm-booking-wrap .pmb-btn--outline {
    background: transparent;
    color: var(--pmb-gold);
    border-color: var(--pmb-gold-dim);
}

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

/* Ghost (border) — secondary action */
.pm-booking-wrap .pmb-btn--ghost {
    background: transparent;
    color: var(--pmb-text-secondary);
    border-color: var(--pmb-border);
}

.pm-booking-wrap .pmb-btn--ghost:hover {
    color: var(--pmb-text-primary);
    border-color: var(--pmb-text-secondary);
}

/* Solid gold — keep for cases where needed */
.pm-booking-wrap .pmb-btn--primary {
    background: var(--pmb-gold);
    color: #0A0A0A;
    border-color: var(--pmb-gold);
}

.pm-booking-wrap .pmb-btn--primary:hover {
    background: #d4b571;
    border-color: #d4b571;
}

/* Solid red — destructive confirm */
.pm-booking-wrap .pmb-btn--danger {
    background: var(--pmb-error);
    color: #fff;
    border-color: var(--pmb-error);
}

.pm-booking-wrap .pmb-btn--danger:hover {
    background: #cc3f44;
    border-color: #cc3f44;
}

.pm-booking-wrap .pmb-btn--danger-ghost {
    background: transparent;
    color: var(--pmb-error);
    border-color: var(--pmb-error);
    padding: 6px 14px;
    font-size: 13px;
}

.pm-booking-wrap .pmb-btn[disabled],
.pm-booking-wrap .pmb-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.pm-booking-wrap .pmb-link {
    background: none;
    border: none;
    color: var(--pmb-gold);
    cursor: pointer;
    font-size: 13px;
    text-decoration: underline;
    padding: 0;
    font-family: inherit;
}

/* ── Error banner ─────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-error-banner {
    background: rgba(229, 72, 77, 0.1);
    border: 1px solid rgba(229, 72, 77, 0.4);
    color: #f87171;
    border-radius: var(--pmb-radius);
    padding: 12px 16px;
    font-size: 14px;
    margin-bottom: 16px;
}

/* ── User card ───────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-user-card {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    background: var(--pmb-bg-page);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    padding: 24px 32px;
    margin-bottom: 24px;
}

.pm-booking-wrap .pmb-user-card__identity {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

.pm-booking-wrap .pmb-user-card__name {
    font-size: 15px;
    font-weight: 500;
    color: var(--pmb-text-primary);
    margin: 0;
}

.pm-booking-wrap .pmb-user-card__email {
    font-size: 13px;
    color: var(--pmb-text-secondary);
    margin: 0;
}

.pm-booking-wrap .pmb-user-card__points {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    text-align: center;
    padding: 0 32px;
}

.pm-booking-wrap .pmb-user-card__points-label {
    font-size: 11px;
    color: var(--pmb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.pm-booking-wrap .pmb-user-card__points-value {
    font-size: 36px;
    font-weight: 700;
    color: var(--pmb-gold);
    line-height: 1;
}

.pm-booking-wrap .pmb-logout-btn {
    font-size: 13px;
    padding: 10px 20px;
    justify-self: end;
}

/* ── Reservations panel ──────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-reservations-panel {
    background: var(--pmb-bg-page);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
}

.pm-booking-wrap .pmb-reservations-panel__title {
    font-size: 14px;
    font-weight: 500;
    color: var(--pmb-text-secondary);
    margin: 0;
    padding: 16px 24px;
    border-bottom: 1px solid var(--pmb-border);
    font-family: var(--font-body);
}

.pm-booking-wrap .pmb-reservations-list {
    display: flex;
    flex-direction: column;
}

.pm-booking-wrap .pmb-reservation-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 24px;
    border-bottom: 1px solid var(--pmb-border);
    gap: 12px;
    flex-wrap: wrap;
}

.pm-booking-wrap .pmb-reservation-item:last-child {
    border-bottom: none;
}

.pm-booking-wrap .pmb-reservation-item__info {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.pm-booking-wrap .pmb-reservation-item__service {
    font-size: 14px;
    font-weight: 500;
    color: var(--pmb-text-primary);
}

.pm-booking-wrap .pmb-reservation-item__datetime {
    font-size: 13px;
    color: var(--pmb-text-secondary);
}

.pm-booking-wrap .pmb-reservation-item__actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}

/* Status badges */
.pm-booking-wrap .pmb-status {
    font-size: 12px;
    padding: 4px 10px;
    border-radius: 20px;
    font-weight: 500;
    white-space: nowrap;
}

.pm-booking-wrap .pmb-status--pending                       { background: rgba(201,169,98,0.15); color: var(--pmb-gold); }
.pm-booking-wrap .pmb-status--confirmed                     { background: rgba(70,167,88,0.15);  color: #46A758; }
.pm-booking-wrap .pmb-status--completed                     { background: rgba(70,167,88,0.1);   color: #46A758; }
.pm-booking-wrap .pmb-status--cancelled                     { background: rgba(229,72,77,0.1);   color: var(--pmb-error); }
.pm-booking-wrap .pmb-status--no_show                       { background: rgba(160,152,136,0.1); color: var(--pmb-text-muted); }
.pm-booking-wrap .pmb-status--awaiting_loyalty_confirmation { background: rgba(201,169,98,0.1);  color: var(--pmb-gold); }

.pm-booking-wrap .pmb-empty-state {
    color: var(--pmb-text-muted);
    font-size: 14px;
    text-align: center;
    padding: 24px;
}

/* ── Guest panel ─────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-guest-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 32px;
    background: var(--pmb-bg-page);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.pm-booking-wrap .pmb-guest-panel__text {
    font-size: 14px;
    color: var(--pmb-text-secondary);
    margin: 0;
}

/* ── Calendar ────────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-calendar {
    background: var(--pmb-bg-surface);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    margin-bottom: 24px;
    overflow: hidden;
}

.pm-booking-wrap .pmb-calendar__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid var(--pmb-border);
}

.pm-booking-wrap .pmb-calendar__nav {
    background: transparent;
    border: 1px solid var(--pmb-border);
    color: var(--pmb-text-secondary);
    border-radius: var(--pmb-radius);
    width: 36px;
    height: 36px;
    cursor: pointer;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.2s, border-color 0.2s;
    font-family: inherit;
}

.pm-booking-wrap .pmb-calendar__nav:hover {
    color: var(--pmb-gold);
    border-color: var(--pmb-gold);
}

.pm-booking-wrap .pmb-calendar__month-label {
    font-size: 16px;
    font-weight: 500;
    color: var(--pmb-text-primary);
    text-transform: capitalize;
    margin: 0;
}

.pm-booking-wrap .pmb-calendar__weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    padding: 16px 24px 8px;
}

.pm-booking-wrap .pmb-calendar__weekdays span {
    text-align: center;
    font-size: 11px;
    font-weight: 600;
    color: var(--pmb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.pm-booking-wrap .pmb-calendar__days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    padding: 0 24px 24px;
}

.pm-booking-wrap .pmb-cal-day {
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--pmb-radius);
    font-size: 14px;
    font-weight: 500;
    cursor: default;
    transition: background 0.15s, color 0.15s;
    border: 1px solid transparent;
    position: relative;
}

.pm-booking-wrap .pmb-cal-day--empty {
    visibility: hidden;
}

.pm-booking-wrap .pmb-cal-day--past,
.pm-booking-wrap .pmb-cal-day--unavailable {
    color: var(--pmb-text-muted);
    cursor: not-allowed;
}

.pm-booking-wrap .pmb-cal-day--available {
    color: var(--pmb-text-primary);
    cursor: pointer;
    background: var(--pmb-border);
    border-color: var(--pmb-border);
}

.pm-booking-wrap .pmb-cal-day--available:hover {
    background: var(--pmb-gold-dim);
    border-color: var(--pmb-gold);
    color: var(--pmb-gold);
}

.pm-booking-wrap .pmb-cal-day--today {
    font-weight: 700;
    border-color: var(--pmb-gold) !important;
}

.pm-booking-wrap .pmb-cal-day--selected {
    background: var(--pmb-gold) !important;
    color: #0A0A0A !important;
    border-color: var(--pmb-gold) !important;
}

.pm-booking-wrap .pmb-calendar__loader {
    text-align: center;
    color: var(--pmb-text-muted);
    font-size: 13px;
    padding: 12px 24px;
}

/* ── Slots ───────────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-slots {
    background: var(--pmb-bg-surface);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    padding: 32px;
    margin-bottom: 24px;
}

.pm-booking-wrap .pmb-slots__header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
}

.pm-booking-wrap .pmb-slots__date {
    font-size: 14px;
    font-weight: 500;
    color: var(--pmb-text-primary);
    margin: 0 0 0 auto;
    font-family: var(--font-body);
}

.pm-booking-wrap .pmb-slots__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 10px;
}

.pm-booking-wrap .pmb-slot-btn {
    background: var(--pmb-bg-card);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    color: var(--pmb-text-primary);
    font-size: 14px;
    font-weight: 500;
    padding: 12px 10px;
    cursor: pointer;
    text-align: center;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
    font-family: inherit;
}

.pm-booking-wrap .pmb-slot-btn:hover,
.pm-booking-wrap .pmb-slot-btn--selected {
    background: var(--pmb-gold-dim);
    border-color: var(--pmb-gold);
    color: var(--pmb-gold);
}

.pm-booking-wrap .pmb-slots__empty {
    color: var(--pmb-text-muted);
    font-size: 14px;
    text-align: center;
    padding: 20px 0;
}

/* ── Reservation form ────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-reservation-form-wrap {
    background: var(--pmb-bg-surface);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    padding: 32px;
}

.pm-booking-wrap .pmb-form-section__header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--pmb-border);
}

.pm-booking-wrap .pmb-form-section__title {
    font-size: 16px;
    font-weight: 500;
    color: var(--pmb-text-primary);
    margin: 0;
}

.pm-booking-wrap .pmb-back-btn {
    padding: 10px 20px;
    font-size: 13px;
    flex-shrink: 0;
}

/* ── Summary ─────────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-summary {
    background: var(--pmb-bg-surface);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    padding: 48px 40px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 28px;
}

.pm-booking-wrap .pmb-summary__icon {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: var(--pmb-gold);
    color: #0A0A0A;
    font-size: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pm-booking-wrap .pmb-summary__header {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.pm-booking-wrap .pmb-summary__title {
    font-size: 28px;
    font-weight: 400;
    color: var(--pmb-text-primary);
    margin: 0;
    font-family: 'Cormorant Garamond', Georgia, serif;
}

.pm-booking-wrap .pmb-summary__body {
    color: var(--pmb-text-secondary);
    font-size: 15px;
    font-weight: 300;
    line-height: 1.7;
    margin: 0;
    max-width: 500px;
}

.pm-booking-wrap .pmb-summary-card {
    background: var(--pmb-bg-page);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    width: 100%;
    max-width: 500px;
    text-align: left;
}

.pm-booking-wrap .pmb-summary-card__header {
    padding: 16px 24px;
    border-bottom: 1px solid var(--pmb-border);
    font-size: 13px;
    font-weight: 500;
    color: var(--pmb-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.pm-booking-wrap .pmb-summary-card__body {
    padding: 20px 24px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.pm-booking-wrap .pmb-summary-row {
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    gap: 16px;
}

.pm-booking-wrap .pmb-summary-row__label {
    color: var(--pmb-text-muted);
}

.pm-booking-wrap .pmb-summary-row__value {
    color: var(--pmb-text-primary);
    font-weight: 500;
    text-align: right;
}

.pm-booking-wrap .pmb-summary__details {
    color: var(--pmb-text-secondary);
    font-size: 14px;
    line-height: 1.7;
    max-width: 500px;
    width: 100%;
}

.pm-booking-wrap .pmb-summary__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
    width: 100%;
}

/* ── Modal ───────────────────────────────────────────────────────────────── */
.pm-booking-wrap .pmb-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pm-booking-wrap .pmb-modal[hidden] {
    display: none !important;
}

.pm-booking-wrap .pmb-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(4px);
}

.pm-booking-wrap .pmb-modal__dialog {
    position: relative;
    background: var(--pmb-bg-card);
    border: 1px solid var(--pmb-border);
    border-radius: var(--pmb-radius);
    padding: 32px;
    max-width: 440px;
    width: 90%;
    z-index: 1;
}

.pm-booking-wrap .pmb-modal__title {
    font-size: 18px;
    font-weight: 500;
    margin: 0 0 12px;
    color: var(--pmb-text-primary);
    font-family: var(--font-body);
}

.pm-booking-wrap .pmb-modal__body {
    color: var(--pmb-text-secondary);
    font-size: 14px;
    margin-bottom: 24px;
    line-height: 1.6;
}

.pm-booking-wrap .pmb-modal__actions {
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    margin-bottom: 10px;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .pm-booking-wrap .pmb-auth-section {
        padding: 28px 20px;
    }

    /* Fields stack to single column on mobile */
    .pm-booking-wrap .pmb-form__row {
        grid-template-columns: 1fr;
    }

    /* Actions stack vertically and center */
    .pm-booking-wrap .pmb-form__actions {
        flex-direction: column;
        align-items: center;
    }

    .pm-booking-wrap .pmb-user-card {
        grid-template-columns: 1fr;
        justify-items: center;
        gap: 24px;
        padding: 28px 20px;
    }

    .pm-booking-wrap .pmb-user-card__identity {
        align-items: center;
        text-align: center;
        gap: 6px;
    }

    .pm-booking-wrap .pmb-user-card__points {
        padding: 0;
        gap: 6px;
    }

    .pm-booking-wrap .pmb-logout-btn {
        justify-self: center;
    }

    .pm-booking-wrap .pmb-reservation-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .pm-booking-wrap .pmb-slots {
        padding: 20px;
    }

    .pm-booking-wrap .pmb-slots__grid {
        grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
    }

    .pm-booking-wrap .pmb-reservation-form-wrap {
        padding: 20px;
    }

    .pm-booking-wrap .pmb-summary {
        padding: 32px 20px;
    }

    .pm-booking-wrap .pmb-guest-panel {
        flex-direction: column;
        align-items: flex-start;
        padding: 16px 20px;
    }

    .pm-booking-wrap .pmb-modal__dialog {
        padding: 24px 20px;
    }

    .pm-booking-wrap .pmb-btn {
        padding: 14px 24px;
    }
}
