/* ============================================================
   Party Booking Wizard — Styles
   ============================================================ */

:root {
    --pb-blue:       var(--pb-primary, #1A84EE);
    --pb-blue-dark:  color-mix(in srgb, var(--pb-primary, #1A84EE) 80%, #000);
    --pb-blue-light: color-mix(in srgb, var(--pb-primary, #1A84EE) 10%, #fff);
    --pb-gold:       #d4a574;
    --pb-gold-dark:  #b8935f;
    --pb-green:      #27ae60;
    --pb-red:        #e74c3c;
    --pb-border:     #e2e8f0;
    --pb-text:       #1e2d3d;
    --pb-muted:      #6b7280;
    --pb-radius:     12px;
    --pb-shadow:     0 4px 24px rgba(0,0,0,.08);
    --pb-transition: 0.2s ease;
}

/* ── Shell ──────────────────────────────────────────────────── */
.pb-app {
    max-width: 860px;
    margin: 32px auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--pb-text);
}

/* ── Progress bar ──────────────────────────────────────────── */
.pb-progress {
    display: flex;
    align-items: center;
    margin-bottom: 32px;
    padding: 0 4px;
    overflow-x: auto;
    scroll-behavior: smooth;
    -ms-overflow-style: none;
    scrollbar-width: none;
}
.pb-progress::-webkit-scrollbar { display: none; }
.pb-progress-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    position: relative;
    min-width: 60px;
}
.pb-progress-step::before {
    content: '';
    position: absolute;
    top: 18px;
    left: calc(-50% + 18px);
    right: calc(50% + 18px);
    height: 2px;
    background: var(--pb-border);
    z-index: 0;
}
.pb-progress-step:first-child::before { display: none; }

.pb-progress-step.done::before,
.pb-progress-step.active::before { background: var(--pb-blue); }

.pb-progress-dot {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--pb-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    color: var(--pb-muted);
    z-index: 1;
    position: relative;
    transition: all var(--pb-transition);
}
.pb-progress-step.done  .pb-progress-dot { background: var(--pb-blue); border-color: var(--pb-blue); color: #fff; }
.pb-progress-step.active .pb-progress-dot { background: var(--pb-blue); border-color: var(--pb-blue); color: #fff; box-shadow: 0 0 0 4px color-mix(in srgb, var(--pb-primary, #1A84EE) 20%, transparent); }

.pb-progress-label {
    font-size: 11px;
    font-weight: 500;
    color: var(--pb-muted);
    margin-top: 6px;
    white-space: nowrap;
    text-align: center;
}
.pb-progress-step.active .pb-progress-label { color: var(--pb-blue); font-weight: 700; }
.pb-progress-step.done   .pb-progress-label { color: var(--pb-blue); }

/* ── Card ───────────────────────────────────────────────────── */
.pb-card {
    background: #fff;
    border: 1px solid var(--pb-border);
    border-radius: var(--pb-radius);
    box-shadow: var(--pb-shadow);
    padding: 28px 32px;
    margin-bottom: 20px;
    animation: pb-fade var(--pb-transition);
}
.pb-card-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--pb-text);
    margin: 0 0 6px;
}
.pb-card-subtitle {
    font-size: 14px;
    color: var(--pb-muted);
    margin: 0 0 24px;
}

/* ── Event grid ─────────────────────────────────────────────── */
.pb-events-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 16px;
}
.pb-event-card {
    border: 2px solid var(--pb-border);
    border-radius: var(--pb-radius);
    overflow: hidden;
    cursor: pointer;
    transition: all var(--pb-transition);
    background: #fff;
}
.pb-event-card:hover { border-color: var(--pb-blue); box-shadow: 0 6px 20px color-mix(in srgb, var(--pb-primary, #1A84EE) 15%, transparent); transform: translateY(-2px); }
.pb-event-card.selected { border-color: var(--pb-blue); background: var(--pb-blue-light); }

.pb-event-img { width: 100%; height: 160px; object-fit: cover; display: block; background: #f3f5f7; }
.pb-event-img-placeholder { width: 100%; height: 160px; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); display: flex; align-items: center; justify-content: center; }
.pb-event-img-placeholder span { font-size: 48px; }

.pb-event-body { padding: 16px; }
.pb-event-name { font-size: 16px; font-weight: 700; color: var(--pb-text); margin: 0 0 6px; }
.pb-event-meta { font-size: 13px; color: var(--pb-muted); display: flex; flex-direction: column; gap: 3px; }
.pb-event-meta span { display: flex; align-items: center; gap: 5px; }
.pb-event-price { font-size: 15px; font-weight: 700; color: var(--pb-blue); margin-top: 8px; }
.pb-event-spots { font-size: 12px; color: var(--pb-green); font-weight: 600; }
.pb-event-spots.low { color: var(--pb-red); }

/* ── Ticket selector ────────────────────────────────────────── */
.pb-event-detail { display: flex; gap: 20px; margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--pb-border); }
.pb-event-detail-img { width: 120px; height: 90px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }
.pb-event-detail-info { flex: 1; }
.pb-event-detail-title { font-size: 18px; font-weight: 700; margin: 0 0 4px; }
.pb-event-detail-meta { font-size: 13px; color: var(--pb-muted); }

.pb-tickets-list { display: flex; flex-direction: column; gap: 12px; }
.pb-ticket-row {
    display: flex;
    align-items: center;
    padding: 14px 16px;
    border: 1px solid var(--pb-border);
    border-radius: 8px;
    gap: 12px;
    transition: border-color var(--pb-transition);
}
.pb-ticket-row.has-tickets { border-color: var(--pb-blue); background: var(--pb-blue-light); }
.pb-ticket-name { flex: 1; font-weight: 600; font-size: 15px; }
.pb-ticket-price { font-size: 14px; font-weight: 700; color: var(--pb-blue); min-width: 70px; text-align: right; }
.pb-ticket-spots { font-size: 12px; color: var(--pb-muted); }
.pb-qty-ctrl { display: flex; align-items: center; gap: 8px; }
.pb-qty-btn {
    width: 30px; height: 30px;
    border: 2px solid var(--pb-blue);
    border-radius: 50%;
    background: #fff;
    color: var(--pb-blue);
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all var(--pb-transition);
    padding: 0;
}
.pb-qty-btn:hover { background: var(--pb-blue); color: #fff; }
.pb-qty-btn:disabled { opacity: .3; cursor: not-allowed; }
.pb-qty-val { font-size: 16px; font-weight: 700; min-width: 24px; text-align: center; }

/* ── Form fields ─────────────────────────────────────────────── */
.pb-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.pb-form-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.pb-form-row.full { grid-column: 1 / -1; }
.pb-label { font-size: 13px; font-weight: 600; color: var(--pb-text); }
.pb-required { color: var(--pb-red); margin-left: 2px; }
.pb-input, .pb-select, .pb-textarea {
    padding: 10px 14px;
    border: 1.5px solid var(--pb-border);
    border-radius: 8px;
    font-size: 15px;
    color: var(--pb-text);
    background: #fff;
    transition: border-color var(--pb-transition);
    width: 100%;
    box-sizing: border-box;
}
.pb-input:focus, .pb-select:focus, .pb-textarea:focus {
    outline: none;
    border-color: var(--pb-blue);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--pb-primary, #1A84EE) 12%, transparent);
}
.pb-input.error, .pb-select.error { border-color: var(--pb-red); }
.pb-textarea { resize: vertical; min-height: 80px; }
.pb-field-error { font-size: 12px; color: var(--pb-red); margin-top: 2px; }

.pb-checkbox-wrap { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; }
.pb-checkbox-wrap input[type="checkbox"] { width: 18px; height: 18px; margin-top: 2px; cursor: pointer; accent-color: var(--pb-blue); }

/* ── Extras panel ────────────────────────────────────────────── */
.pb-extras-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; padding-bottom: 14px; border-bottom: 2px solid var(--pb-border); }
.pb-ext-tab {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 7px 16px;
    background: #fff; border: 2px solid var(--pb-border); border-radius: 24px;
    cursor: pointer; font-size: 13px; font-weight: 600; color: #555;
    transition: all var(--pb-transition);
}
.pb-ext-tab:hover { border-color: var(--pb-blue); color: var(--pb-blue); }
.pb-ext-tab.active { background: var(--pb-blue); border-color: var(--pb-blue); color: #fff; box-shadow: 0 3px 10px color-mix(in srgb, var(--pb-primary, #1A84EE) 30%, transparent); }

.pb-ext-subtabs { display: flex; gap: 6px; margin-bottom: 14px; padding: 10px 12px; background: var(--pb-blue-light); border-radius: 8px; flex-wrap: wrap; }
.pb-ext-subtab { padding: 4px 14px; background: #fff; border: 1px solid var(--pb-border); border-radius: 20px; cursor: pointer; font-size: 12px; font-weight: 600; color: #555; transition: all var(--pb-transition); }
.pb-ext-subtab:hover { border-color: var(--pb-blue); color: var(--pb-blue); }
.pb-ext-subtab.active { background: var(--pb-blue); border-color: var(--pb-blue); color: #fff; }

.pb-ext-panel { display: none; }
.pb-ext-panel.active { display: block; animation: pb-fade var(--pb-transition); }
.pb-ext-subpanel { display: none; }
.pb-ext-subpanel.active { display: block; }

.pb-ext-grid { display: flex; flex-wrap: wrap; gap: 12px; padding: 4px 0 12px; }
.pb-ext-card {
    width: 148px;
    border: 2px solid var(--pb-border);
    border-radius: var(--pb-radius);
    overflow: hidden;
    cursor: pointer;
    transition: all var(--pb-transition);
    background: #fff;
    display: flex; flex-direction: column;
    position: relative;
    user-select: none;
}
.pb-ext-card:hover { border-color: var(--pb-blue); transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,.1); }
.pb-ext-card.selected { border-color: var(--pb-blue); background: var(--pb-blue-light); }
.pb-ext-card.selected::after {
    content: '✓';
    position: absolute; top: 7px; right: 7px;
    width: 22px; height: 22px; line-height: 22px;
    background: var(--pb-blue); color: #fff;
    border-radius: 50%; font-size: 13px; font-weight: 700;
    text-align: center; box-shadow: 0 2px 6px rgba(0,0,0,.2); z-index: 2;
}
.pb-ext-img { width: 100%; height: 120px; overflow: hidden; background: #f3f5f7; display: flex; align-items: center; justify-content: center; }
.pb-ext-img img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--pb-transition); }
.pb-ext-card:hover .pb-ext-img img { transform: scale(1.06); }
.pb-ext-ph { font-size: 38px; font-weight: 700; color: var(--pb-blue); opacity: .3; }
.pb-ext-info { padding: 8px 8px 10px; text-align: center; }
.pb-ext-name { font-size: 12px; font-weight: 600; color: var(--pb-text); line-height: 1.3; }
.pb-ext-price { font-size: 13px; font-weight: 700; color: var(--pb-blue-dark); margin-top: 2px; }

.pb-no-extras { padding: 20px; text-align: center; color: var(--pb-muted); font-size: 14px; }

/* ── Order Summary ────────────────────────────────────────────── */
.pb-summary-section { margin-bottom: 20px; }
.pb-summary-section-title { font-size: 13px; font-weight: 700; color: var(--pb-muted); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 10px; }
.pb-summary-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; font-size: 14px; color: var(--pb-text); border-bottom: 1px dashed var(--pb-border); }
.pb-summary-row:last-child { border-bottom: none; }
.pb-summary-row .label { color: var(--pb-muted); }
.pb-summary-row .value { font-weight: 600; }
.pb-summary-total { display: flex; justify-content: space-between; align-items: center; padding: 14px 0 0; font-size: 17px; font-weight: 700; border-top: 2px solid var(--pb-border); margin-top: 6px; }
.pb-summary-advance { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; background: #fff8f0; border: 1px solid #f0d9b8; border-radius: 8px; margin-top: 12px; }
.pb-summary-advance .label { font-size: 13px; font-weight: 600; color: #7a5c2e; }
.pb-summary-advance .value { font-size: 16px; font-weight: 800; color: var(--pb-gold-dark); }
.pb-summary-balance { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; font-size: 13px; color: var(--pb-muted); margin-top: 6px; }

/* ── Payment ─────────────────────────────────────────────────── */
.pb-pay-info { background: var(--pb-blue-light); border: 1px solid #b8d8f8; border-radius: 10px; padding: 20px; margin-bottom: 24px; }
.pb-pay-info h4 { margin: 0 0 8px; color: var(--pb-blue); font-size: 15px; }
.pb-pay-info p { margin: 0; font-size: 13px; color: #444; line-height: 1.6; }
.pb-pay-amount { font-size: 36px; font-weight: 800; color: var(--pb-blue); text-align: center; margin: 20px 0; }
.pb-pay-amount small { font-size: 14px; font-weight: 400; color: var(--pb-muted); display: block; margin-top: 4px; }

/* ── Confirmation ────────────────────────────────────────────── */
.pb-congrats { text-align: center; padding: 20px 0 32px; }
.pb-congrats-icon { font-size: 64px; line-height: 1; margin-bottom: 16px; }
.pb-congrats h2 { font-size: 26px; font-weight: 800; color: var(--pb-text); margin: 0 0 8px; }
.pb-congrats p { font-size: 15px; color: var(--pb-muted); margin: 0 0 24px; }
.pb-booking-ref { display: inline-block; padding: 6px 16px; background: var(--pb-blue-light); border: 1px solid var(--pb-blue); border-radius: 20px; font-size: 13px; font-weight: 700; color: var(--pb-blue); margin-bottom: 28px; }
.pb-congrats-extras { margin-top: 20px; text-align: left; }
.pb-congrats-extras h4 { font-size: 14px; font-weight: 700; color: var(--pb-text); margin: 0 0 10px; }
.pb-congrats-extras ul { list-style: none; margin: 0; padding: 0; }
.pb-congrats-extras ul li { display: flex; justify-content: space-between; font-size: 13px; padding: 5px 0; border-bottom: 1px dashed var(--pb-border); color: var(--pb-text); }
.pb-congrats-extras ul li:last-child { border-bottom: none; }
.pb-arrival-note { font-size: 13px; color: var(--pb-muted); text-align: center; margin-top: 12px; font-style: italic; }

/* ── Buttons ─────────────────────────────────────────────────── */
.pb-actions { display: flex; gap: 12px; justify-content: space-between; align-items: center; margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--pb-border); }
.pb-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 24px;
    border-radius: 8px;
    font-size: 15px; font-weight: 700;
    cursor: pointer;
    border: none;
    transition: all var(--pb-transition);
}
.pb-btn-primary { background: var(--pb-blue); color: #fff; }
.pb-btn-primary:hover { background: var(--pb-blue-dark); }
.pb-btn-primary:disabled { opacity: .5; cursor: not-allowed; }
.pb-btn-secondary { background: #fff; color: var(--pb-text); border: 2px solid var(--pb-border); }
.pb-btn-secondary:hover { border-color: var(--pb-blue); color: var(--pb-blue); }
.pb-btn-pay { background: #2e7d32; color: #fff; font-size: 17px; padding: 14px 32px; width: 100%; justify-content: center; }
.pb-btn-pay:hover { background: #1b5e20; }
.pb-btn-pay:disabled { opacity: .5; cursor: not-allowed; }

/* ── Error / Loading ─────────────────────────────────────────── */
.pb-error { padding: 14px 16px; background: #fef2f2; border: 1px solid #fecaca; border-radius: 8px; color: var(--pb-red); font-size: 14px; margin-bottom: 16px; }
.pb-loading { text-align: center; padding: 40px; color: var(--pb-muted); font-size: 15px; }
.pb-spinner { display: inline-block; width: 24px; height: 24px; border: 3px solid #e5e7eb; border-top-color: var(--pb-blue); border-radius: 50%; animation: pb-spin 0.7s linear infinite; vertical-align: middle; margin-right: 8px; }

/* ── Animations ──────────────────────────────────────────────── */
@keyframes pb-fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pb-spin { to { transform: rotate(360deg); } }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 640px) {
    .pb-card { padding: 20px 16px; }
    .pb-form-grid { grid-template-columns: 1fr; }
    .pb-events-grid { grid-template-columns: 1fr; }
    .pb-ext-card { width: calc(50% - 6px); }
    .pb-actions { flex-direction: column-reverse; }
    .pb-btn { width: 100%; justify-content: center; }
}
@media (max-width: 380px) {
    .pb-ext-card { width: 100%; }
}

/* ============================================================
   Frontend Component Styles
   ============================================================ */

/* Calendar */
.pb-cal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.pb-cal-header h3 { margin: 0; font-size: 18px; }
.pb-cal-nav {
    width: 36px; height: 36px;
    border-radius: 50%;
    border: 1px solid #ddd;
    background: #fff;
    cursor: pointer;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .15s;
}
.pb-cal-nav:hover { background: var(--pb-primary, #1A84EE); color: #fff; border-color: var(--pb-primary, #1A84EE); }

#pb-app .pb-cal-grid {
    display: grid !important;
    grid-template-columns: repeat(7, 1fr) !important;
    gap: 4px !important;
}
.pb-cal-dow {
    text-align: center;
    font-size: 12px;
    font-weight: 600;
    color: #888;
    padding: 8px 0;
    text-transform: uppercase;
}
.pb-cal-day {
    text-align: center;
    padding: 10px 4px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    transition: all .15s;
    border: 1px solid transparent;
}
.pb-cal-day:hover { background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff); }
.pb-cal-day.today { font-weight: 700; border-color: var(--pb-primary, #1A84EE); }
.pb-cal-day.selected { background: var(--pb-primary, #1A84EE); color: #fff; font-weight: 600; }
.pb-cal-day.disabled { color: #ccc; cursor: not-allowed; pointer-events: none; }
.pb-cal-day.empty { visibility: hidden; }
.pb-cal-day.available { color: var(--pb-primary, #1A84EE); font-weight: 500; }

/* Venue cards */
.pb-venue-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}
.pb-venue-card {
    background: #fff;
    border: 2px solid #e8e8e8;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    transition: all .2s;
    text-align: center;
}
.pb-venue-card:hover { border-color: var(--pb-primary, #1A84EE); box-shadow: 0 4px 12px color-mix(in srgb, var(--pb-primary, #1A84EE) 15%, transparent); transform: translateY(-2px); }
.pb-venue-card.selected { border-color: var(--pb-primary, #1A84EE); background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff); box-shadow: 0 4px 12px color-mix(in srgb, var(--pb-primary, #1A84EE) 20%, transparent); }
.pb-venue-img { width: 100%; height: 100px; object-fit: cover; }
.pb-venue-placeholder {
    width: 100%; height: 100px;
    background: linear-gradient(135deg, var(--pb-primary, #1A84EE) 0%, color-mix(in srgb, var(--pb-primary, #1A84EE) 80%, #000) 100%);
    display: flex; align-items: center; justify-content: center;
    font-size: 32px; font-weight: 700; color: #fff;
}
.pb-venue-name { padding: 10px 8px; font-weight: 600; font-size: 14px; color: #333; }
.pb-venue-address { padding: 0 8px 10px; font-size: 12px; color: #888; }
.pb-section-label { font-size: 16px; color: #555; margin: 20px 0 10px; font-weight: 600; }

/* Time slot cards */
.pb-slots-section { margin-top: 24px; }
.pb-slots-section h3 { font-size: 16px; margin: 0 0 12px; color: #333; }
.pb-slots-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
}
.pb-slot-card {
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 10px;
    padding: 14px 10px;
    text-align: center;
    cursor: pointer;
    transition: all .2s;
}
.pb-slot-card:hover { border-color: var(--pb-primary, #1A84EE); background: color-mix(in srgb, var(--pb-primary, #1A84EE) 5%, #fff); }
.pb-slot-card.selected { border-color: var(--pb-primary, #1A84EE); background: var(--pb-primary, #1A84EE); color: #fff; }
.pb-slot-card.selected .pb-slot-time { color: #fff; }
.pb-slot-card.selected .pb-slot-avail { color: rgba(255,255,255,.8); }
.pb-slot-time { font-size: 15px; font-weight: 600; color: #333; }
.pb-slot-avail { font-size: 11px; color: #888; margin-top: 4px; }
.pb-no-slots { color: #888; font-style: italic; padding: 16px 0; }

/* Progress bar improvements */
.pb-progress {
    display: flex;
    justify-content: center;
    gap: 0;
    margin-bottom: 24px;
    overflow-x: auto;
    padding: 8px 0;
    scroll-behavior: smooth;
    -ms-overflow-style: none;
    scrollbar-width: none;
}

/* Event cards - frontend */
.pb-event-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
}
.pb-event-card-fe {
    background: #fff;
    border: 2px solid #e8e8e8;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    transition: all .2s;
}
.pb-event-card-fe:hover { border-color: var(--pb-primary, #1A84EE); box-shadow: 0 4px 16px color-mix(in srgb, var(--pb-primary, #1A84EE) 15%, transparent); }
.pb-event-card-fe.selected { border-color: var(--pb-primary, #1A84EE); }
.pb-event-card-fe img { width: 100%; height: 180px; object-fit: cover; }
.pb-event-card-fe__body { padding: 14px; }
.pb-event-card-fe__body h3 { margin: 0 0 6px; font-size: 17px; }
.pb-event-card-fe__body p { margin: 0; font-size: 13px; color: #666; }
.pb-event-card-fe__meta { display: flex; gap: 12px; margin-top: 10px; font-size: 13px; color: #555; }

/* Ticket rows */
.pb-ticket-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border: 1px solid #e8e8e8;
    border-radius: 10px;
    margin-bottom: 8px;
    background: #fff;
}
.pb-ticket-info h4 { margin: 0; font-size: 15px; }
.pb-ticket-info .pb-ticket-price { color: var(--pb-primary, #1A84EE); font-weight: 600; font-size: 14px; }
.pb-qty-ctrl {
    display: flex;
    align-items: center;
    gap: 12px;
}
.pb-qty-btn {
    width: 34px; height: 34px;
    border-radius: 50%;
    border: 2px solid var(--pb-primary, #1A84EE);
    background: #fff;
    color: var(--pb-primary, #1A84EE);
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .15s;
}
.pb-qty-btn:hover { background: var(--pb-primary, #1A84EE); color: #fff; }
.pb-qty-count { font-size: 18px; font-weight: 700; min-width: 24px; text-align: center; }

/* Extras cards */
.pb-ext-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid #e0e0e0;
    margin-bottom: 16px;
}
.pb-ext-tab {
    padding: 10px 18px;
    border: none;
    background: none;
    font-size: 14px;
    font-weight: 500;
    color: #888;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all .15s;
}
.pb-ext-tab:hover { color: var(--pb-primary, #1A84EE); }
.pb-ext-tab.active { color: var(--pb-primary, #1A84EE); border-bottom-color: var(--pb-primary, #1A84EE); }

.pb-ext-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
}
.pb-ext-card {
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    transition: all .2s;
    position: relative;
    text-align: center;
}
.pb-ext-card:hover { border-color: var(--pb-primary, #1A84EE); }
.pb-ext-card.selected { border-color: var(--pb-primary, #1A84EE); background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff); }
.pb-ext-card img { width: 100%; height: 90px; object-fit: cover; }
.pb-ext-card__ph {
    width: 100%; height: 90px;
    background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px; color: var(--pb-primary, #1A84EE); font-weight: 700;
}
.pb-ext-card__info { padding: 8px; }
.pb-ext-card__name { font-size: 13px; font-weight: 600; }
.pb-ext-card__price { font-size: 12px; color: var(--pb-primary, #1A84EE); font-weight: 500; }
.pb-ext-card__check {
    position: absolute;
    top: 6px; right: 6px;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: var(--pb-primary, #1A84EE);
    color: #fff;
    font-size: 12px;
    display: none;
    align-items: center;
    justify-content: center;
}
.pb-ext-card.selected .pb-ext-card__check { display: flex; }

/* Summary */
.pb-summary-section { margin-bottom: 16px; }
.pb-summary-section h3 { font-size: 15px; margin: 0 0 8px; color: #333; border-bottom: 1px solid #f0f0f0; padding-bottom: 8px; }
.pb-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 14px;
}
.pb-summary-row.total { font-weight: 700; font-size: 16px; border-top: 2px solid #333; margin-top: 8px; padding-top: 10px; }
.pb-summary-row .advance { color: #46b450; font-weight: 600; }
.pb-summary-row .balance { color: #dc3545; }

/* Payment */
.pb-pay-amount {
    text-align: center;
    margin: 24px 0;
}
.pb-pay-amount .pb-pay-label { font-size: 14px; color: #666; }
.pb-pay-amount .pb-pay-value { font-size: 36px; font-weight: 700; color: var(--pb-primary, #1A84EE); }

/* Confirmation */
.pb-done-icon {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: #46b450;
    color: #fff;
    font-size: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
}
.pb-booking-ref {
    background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff);
    border-radius: 8px;
    padding: 12px 20px;
    display: inline-block;
    font-size: 18px;
    font-weight: 700;
    color: var(--pb-primary, #1A84EE);
    letter-spacing: 1px;
}

/* Buttons */
.pb-btn {
    padding: 12px 28px;
    border-radius: 8px;
    font-size: 15px;
    font-weight: 600;
    border: 2px solid #e0e0e0;
    background: #fff;
    cursor: pointer;
    transition: all .15s;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.pb-btn:hover { border-color: var(--pb-primary, #1A84EE); color: var(--pb-primary, #1A84EE); }
.pb-btn-primary { background: var(--pb-primary, #1A84EE); color: #fff; border-color: var(--pb-primary, #1A84EE); }
.pb-btn-primary:hover { background: color-mix(in srgb, var(--pb-primary, #1A84EE) 80%, #000); border-color: color-mix(in srgb, var(--pb-primary, #1A84EE) 80%, #000); }

/* Actions bar */
.pb-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 24px;
    padding-top: 16px;
    border-top: 1px solid #f0f0f0;
}

/* Loading + Error */
.pb-loading { text-align: center; padding: 30px; color: #888; font-size: 15px; }
.pb-error { background: #fef2f2; border: 1px solid #fecaca; border-radius: 8px; padding: 12px 16px; color: #dc2626; margin-bottom: 16px; }

/* Header */
.pb-hdr h2 { margin: 0 0 6px; font-size: 26px; color: #1e1e1e; }
.pb-hdr p { margin: 0 0 20px; color: #888; font-size: 14px; }

/* Form */
.pb-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.pb-form-grid.full { grid-template-columns: 1fr; }
.pb-form-group label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: #555;
    margin-bottom: 4px;
}
.pb-form-group input,
.pb-form-group select,
.pb-form-group textarea {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 14px;
    transition: border-color .15s;
    box-sizing: border-box;
}
.pb-form-group input:focus,
.pb-form-group select:focus,
.pb-form-group textarea:focus {
    outline: none;
    border-color: var(--pb-primary, #1A84EE);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--pb-primary, #1A84EE) 10%, transparent);
}

/* Card base */
.pb-card {
    background: #fff;
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 4px 24px rgba(0,0,0,.08);
    max-width: 800px;
    margin: 0 auto;
}

/* ============================================================
   THEME OVERRIDE — high specificity to beat Eventchamp/WPBakery
   Color uses var(--pb-primary) set via inline style from settings
   ============================================================ */
#pb-app { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif !important; --pb-primary: var(--pb-primary, #1A84EE); }
#pb-app * { box-sizing: border-box !important; }

/* ── Progress Bar (fixed) ── */
#pb-app .pb-progress { display: flex !important; justify-content: center !important; align-items: center !important; margin: 0 auto 28px !important; max-width: 800px !important; padding: 0 16px !important; flex-wrap: nowrap !important; overflow-x: auto !important; gap: 0 !important; scroll-behavior: smooth !important; -ms-overflow-style: none !important; scrollbar-width: none !important; }
#pb-app .pb-progress::-webkit-scrollbar { display: none !important; }
#pb-app .pb-step { display: flex !important; align-items: center !important; gap: 6px !important; white-space: nowrap !important; font-size: 12px !important; color: #aaa !important; position: relative !important; padding: 0 4px !important; }
#pb-app .pb-step::after { content: '' !important; display: inline-block !important; width: 20px !important; height: 2px !important; background: #ddd !important; margin-left: 4px !important; flex-shrink: 0 !important; }
#pb-app .pb-step:last-child::after { display: none !important; }
#pb-app .pb-step-num { width: 26px !important; height: 26px !important; border-radius: 50% !important; background: #e8e8e8 !important; color: #888 !important; font-size: 12px !important; font-weight: 700 !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; flex-shrink: 0 !important; }
#pb-app .pb-step-label { font-size: 11px !important; font-weight: 500 !important; }
#pb-app .pb-step.active .pb-step-num { background: var(--pb-primary) !important; color: #fff !important; }
#pb-app .pb-step.active .pb-step-label { color: var(--pb-primary) !important; font-weight: 700 !important; }
#pb-app .pb-step.done .pb-step-num { background: var(--pb-primary) !important; color: #fff !important; }
#pb-app .pb-step.done .pb-step-label { color: #555 !important; }
#pb-app .pb-step.done::after { background: var(--pb-primary) !important; }
#pb-app .pb-card { display: block !important; background: #fff !important; border-radius: 16px !important; padding: 32px !important; box-shadow: 0 4px 24px rgba(0,0,0,.08) !important; max-width: 800px !important; margin: 0 auto !important; }
#pb-app .pb-cal-header { display: flex !important; align-items: center !important; justify-content: space-between !important; margin-bottom: 16px !important; }
#pb-app .pb-cal-header h3 { margin: 0 !important; font-size: 18px !important; color: #333 !important; }
#pb-app .pb-cal-nav { width: 36px !important; height: 36px !important; min-width: 36px !important; border-radius: 50% !important; border: 1px solid #ddd !important; background: #fff !important; cursor: pointer !important; font-size: 20px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; color: #333 !important; padding: 0 !important; line-height: 1 !important; -webkit-appearance: none !important; appearance: none !important; }
#pb-app .pb-cal-nav:hover { background: var(--pb-primary, #1A84EE) !important; color: #fff !important; border-color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-cal-grid { display: grid !important; grid-template-columns: repeat(7, 1fr) !important; gap: 4px !important; }
#pb-app .pb-cal-dow { text-align: center !important; font-size: 12px !important; font-weight: 600 !important; color: #888 !important; padding: 8px 0 !important; text-transform: uppercase !important; }
#pb-app .pb-cal-day { text-align: center !important; padding: 10px 4px !important; border-radius: 8px !important; cursor: pointer !important; font-size: 14px !important; border: 1px solid transparent !important; display: block !important; }
#pb-app .pb-cal-day:hover { background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff) !important; }
#pb-app .pb-cal-day.today { font-weight: 700 !important; border-color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-cal-day.selected { background: var(--pb-primary, #1A84EE) !important; color: #fff !important; font-weight: 600 !important; }
#pb-app .pb-cal-day.disabled { color: #ccc !important; cursor: not-allowed !important; pointer-events: none !important; }
#pb-app .pb-cal-day.empty { visibility: hidden !important; }
#pb-app .pb-cal-day.available { color: var(--pb-primary, #1A84EE) !important; font-weight: 500 !important; }
#pb-app .pb-venue-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important; gap: 14px !important; margin-bottom: 20px !important; }
#pb-app .pb-venue-grid--rich, #pb-app .pb-venue-grid--single { grid-template-columns: 1fr !important; }
#pb-app .pb-venue-card { background: #fff !important; border: 2px solid #e8e8e8 !important; border-radius: 12px !important; overflow: hidden !important; cursor: pointer !important; text-align: center !important; display: block !important; }
#pb-app .pb-venue-card:hover { border-color: var(--pb-primary, #1A84EE) !important; box-shadow: 0 4px 12px color-mix(in srgb, var(--pb-primary, #1A84EE) 15%, transparent) !important; transform: translateY(-2px) !important; }
#pb-app .pb-venue-card.selected { border-color: var(--pb-primary, #1A84EE) !important; background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff) !important; }
#pb-app .pb-venue-img { width: 100% !important; height: 100px !important; object-fit: cover !important; display: block !important; }
#pb-app .pb-venue-placeholder { width: 100% !important; height: 100px !important; background: linear-gradient(135deg, var(--pb-primary, #1A84EE) 0%, color-mix(in srgb, var(--pb-primary, #1A84EE) 80%, #000) 100%) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 32px !important; font-weight: 700 !important; color: #fff !important; }
#pb-app .pb-venue-name { padding: 10px 8px !important; font-weight: 600 !important; font-size: 14px !important; color: #333 !important; }
#pb-app .pb-slots-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important; gap: 10px !important; }
#pb-app .pb-slot-card { background: #fff !important; border: 2px solid #e0e0e0 !important; border-radius: 10px !important; padding: 14px 10px !important; text-align: center !important; cursor: pointer !important; display: block !important; }
#pb-app .pb-slot-card:hover { border-color: var(--pb-primary, #1A84EE) !important; background: color-mix(in srgb, var(--pb-primary, #1A84EE) 5%, #fff) !important; }
#pb-app .pb-slot-card.selected { border-color: var(--pb-primary, #1A84EE) !important; background: var(--pb-primary, #1A84EE) !important; color: #fff !important; }
#pb-app .pb-slot-time { font-size: 15px !important; font-weight: 600 !important; }
#pb-app .pb-ext-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important; gap: 12px !important; }
#pb-app .pb-ext-card { background: #fff !important; border: 2px solid #e0e0e0 !important; border-radius: 10px !important; overflow: hidden !important; cursor: pointer !important; display: block !important; text-align: center !important; position: relative !important; }
#pb-app .pb-ext-card.selected { border-color: var(--pb-primary, #1A84EE) !important; background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff) !important; }
#pb-app .pb-ticket-row { display: flex !important; align-items: center !important; justify-content: space-between !important; padding: 14px 16px !important; border: 1px solid #e8e8e8 !important; border-radius: 10px !important; margin-bottom: 8px !important; background: #fff !important; }
#pb-app .pb-qty-ctrl { display: flex !important; align-items: center !important; gap: 12px !important; }
#pb-app .pb-qty-btn { width: 34px !important; height: 34px !important; border-radius: 50% !important; border: 2px solid var(--pb-primary, #1A84EE) !important; background: #fff !important; color: var(--pb-primary, #1A84EE) !important; font-size: 18px !important; cursor: pointer !important; display: flex !important; align-items: center !important; justify-content: center !important; }
#pb-app .pb-qty-btn:hover { background: var(--pb-primary, #1A84EE) !important; color: #fff !important; }
#pb-app .pb-form-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 14px !important; }
#pb-app .pb-form-group input,
#pb-app .pb-form-group select,
#pb-app .pb-form-group textarea { width: 100% !important; padding: 10px 12px !important; border: 1px solid #ddd !important; border-radius: 8px !important; font-size: 14px !important; }
#pb-app .pb-form-group input:focus,
#pb-app .pb-form-group select:focus { border-color: var(--pb-primary, #1A84EE) !important; box-shadow: 0 0 0 3px color-mix(in srgb, var(--pb-primary, #1A84EE) 10%, transparent) !important; outline: none !important; }
#pb-app .pb-actions { display: flex !important; justify-content: space-between !important; align-items: center !important; margin-top: 24px !important; padding-top: 16px !important; border-top: 1px solid #f0f0f0 !important; }
#pb-app .pb-btn { padding: 12px 28px !important; border-radius: 8px !important; font-size: 15px !important; font-weight: 600 !important; border: 2px solid #e0e0e0 !important; background: #fff !important; cursor: pointer !important; text-transform: uppercase !important; letter-spacing: .5px !important; }
#pb-app .pb-btn-primary { background: var(--pb-primary, #1A84EE) !important; color: #fff !important; border-color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-btn-primary:hover { background: color-mix(in srgb, var(--pb-primary, #1A84EE) 80%, #000) !important; }
#pb-app .pb-hdr h2 { font-size: 26px !important; color: #1e1e1e !important; margin: 0 0 6px !important; }
#pb-app .pb-hdr p { color: #888 !important; font-size: 14px !important; margin: 0 0 20px !important; }
#pb-app .pb-progress { display: flex !important; justify-content: center !important; gap: 0 !important; margin-bottom: 24px !important; overflow-x: auto !important; scroll-behavior: smooth !important; -ms-overflow-style: none !important; scrollbar-width: none !important; }
#pb-app .pb-section-label { font-size: 16px !important; color: #555 !important; margin: 20px 0 10px !important; font-weight: 600 !important; display: block !important; }
#pb-app .pb-summary-row { display: flex !important; justify-content: space-between !important; padding: 6px 0 !important; }
#pb-app .pb-pay-amount { text-align: center !important; margin: 24px 0 !important; }
#pb-app .pb-pay-value { font-size: 36px !important; font-weight: 700 !important; color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-done-icon { width: 64px !important; height: 64px !important; border-radius: 50% !important; background: #46b450 !important; color: #fff !important; font-size: 32px !important; display: flex !important; align-items: center !important; justify-content: center !important; margin: 0 auto 16px !important; }
#pb-app .pb-booking-ref { background: color-mix(in srgb, var(--pb-primary, #1A84EE) 10%, #fff) !important; border: 1px solid color-mix(in srgb, var(--pb-primary, #1A84EE) 30%, #fff) !important; border-radius: 8px !important; padding: 12px 20px !important; display: inline-block !important; font-size: 18px !important; font-weight: 700 !important; color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-error { background: #fef2f2 !important; border: 1px solid #fecaca !important; border-radius: 8px !important; padding: 12px 16px !important; color: #dc2626 !important; }
#pb-app .pb-loading { text-align: center !important; padding: 30px !important; color: #888 !important; }
#pb-app .pb-no-slots { color: #888 !important; font-style: italic !important; padding: 16px 0 !important; }
#pb-app .pb-event-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important; gap: 16px !important; }

/* ── Extras Tabs — blue theme, not orange ── */
#pb-app .pb-ext-tabs { display: flex !important; gap: 0 !important; border-bottom: 2px solid #e0e0e0 !important; margin-bottom: 20px !important; background: none !important; padding: 0 !important; }
#pb-app .pb-ext-tab { padding: 10px 20px !important; border: none !important; background: none !important; font-size: 14px !important; font-weight: 600 !important; color: #888 !important; cursor: pointer !important; border-bottom: 3px solid transparent !important; margin-bottom: -2px !important; text-transform: uppercase !important; letter-spacing: .5px !important; transition: all .15s !important; }
#pb-app .pb-ext-tab:hover { color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-ext-tab.active { color: var(--pb-primary, #1A84EE) !important; border-bottom-color: var(--pb-primary, #1A84EE) !important; background: none !important; }
/* Extra card image height fix */
#pb-app .pb-ext-card img { width: 100% !important; height: 100px !important; object-fit: cover !important; display: block !important; }
#pb-app .pb-ext-card__ph { width: 100% !important; height: 100px !important; background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 24px !important; color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-ext-card__info { padding: 10px 8px !important; }
#pb-app .pb-ext-card__name { font-size: 13px !important; font-weight: 600 !important; color: #333 !important; display: block !important; }
#pb-app .pb-ext-card__price { font-size: 12px !important; color: var(--pb-primary, #1A84EE) !important; font-weight: 500 !important; display: block !important; }
#pb-app .pb-ext-card__check { position: absolute !important; top: 6px !important; right: 6px !important; width: 22px !important; height: 22px !important; border-radius: 50% !important; background: var(--pb-primary, #1A84EE) !important; color: #fff !important; font-size: 12px !important; display: none !important; align-items: center !important; justify-content: center !important; }
#pb-app .pb-ext-card.selected .pb-ext-card__check { display: flex !important; }

/* ── Terms & Conditions checkbox ── */
#pb-app .pb-tc-row { margin-top: 16px !important; padding: 14px 16px !important; background: #f8f9fa !important; border-radius: 8px !important; border: 1px solid #e0e0e0 !important; }
#pb-app .pb-tc-row label { display: flex !important; align-items: flex-start !important; gap: 10px !important; font-size: 13px !important; color: #555 !important; cursor: pointer !important; }
#pb-app .pb-tc-row input[type="checkbox"] { width: 18px !important; height: 18px !important; margin-top: 2px !important; accent-color: var(--pb-primary, #1A84EE) !important; flex-shrink: 0 !important; }

/* ── Ticket total spacing ── */
#pb-app .pb-ticket-total { margin-top: 12px !important; font-size: 14px !important; color: #555 !important; }

/* ── Event card frontend ── */
#pb-app .pb-event-card-fe { background: #fff !important; border: 2px solid #e8e8e8 !important; border-radius: 12px !important; overflow: hidden !important; cursor: pointer !important; transition: all .2s !important; display: block !important; }
#pb-app .pb-event-card-fe:hover { border-color: var(--pb-primary, #1A84EE) !important; box-shadow: 0 4px 16px color-mix(in srgb, var(--pb-primary, #1A84EE) 15%, transparent) !important; }
#pb-app .pb-event-card-fe.selected { border-color: var(--pb-primary, #1A84EE) !important; }
#pb-app .pb-event-card-fe img { width: 100% !important; height: 180px !important; object-fit: cover !important; display: block !important; }
#pb-app .pb-event-card-fe__body { padding: 14px !important; }
#pb-app .pb-event-card-fe__body h3 { margin: 0 0 6px !important; font-size: 17px !important; color: #333 !important; }
#pb-app .pb-event-card-fe__body p { margin: 0 !important; font-size: 13px !important; color: #666 !important; }
#pb-app .pb-event-card-fe__meta { display: flex !important; gap: 12px !important; margin-top: 10px !important; font-size: 13px !important; color: #555 !important; }

/* ── Summary polish ── */
#pb-app .pb-summary-section { margin-bottom: 20px !important; }
#pb-app .pb-summary-section h3 { font-size: 15px !important; margin: 0 0 10px !important; color: #333 !important; border-bottom: 1px solid #f0f0f0 !important; padding-bottom: 8px !important; }
#pb-app .pb-summary-row { display: flex !important; justify-content: space-between !important; padding: 6px 0 !important; font-size: 14px !important; color: #555 !important; }
#pb-app .pb-summary-row.total { font-weight: 700 !important; font-size: 17px !important; color: #333 !important; border-top: 2px solid #333 !important; margin-top: 10px !important; padding-top: 12px !important; }
#pb-app .pb-summary-row .advance { color: #27ae60 !important; font-weight: 600 !important; }
#pb-app .pb-summary-row .balance { color: #e74c3c !important; }

/* ── Payment step ── */
#pb-app .pb-pay-label { font-size: 14px !important; color: #666 !important; margin-bottom: 8px !important; display: block !important; }

/* ── Confirmation step ── */
#pb-app .pb-done-text { text-align: center !important; margin-bottom: 24px !important; }
#pb-app .pb-done-text h2 { color: #27ae60 !important; font-size: 24px !important; }
#pb-app .pb-done-details { background: #f8f9fa !important; border-radius: 10px !important; padding: 20px !important; margin: 20px 0 !important; }
#pb-app .pb-done-details table { width: 100% !important; border-collapse: collapse !important; }
#pb-app .pb-done-details td { padding: 6px 8px !important; font-size: 14px !important; border-bottom: 1px solid #eee !important; }
#pb-app .pb-done-details td:first-child { font-weight: 600 !important; color: #555 !important; width: 140px !important; }

/* ============================================================
   ACTUAL JS CLASS NAMES — matching what party-booking.js renders
   ============================================================ */

/* ── Extras Tabs (JS: .pb-tabs, .pb-tab) ── */
#pb-app .pb-tabs { display: flex !important; gap: 0 !important; border-bottom: 2px solid #e0e0e0 !important; margin-bottom: 20px !important; background: none !important; padding: 0 !important; flex-wrap: wrap !important; }
#pb-app .pb-tab { padding: 10px 20px !important; border: none !important; background: none !important; font-size: 13px !important; font-weight: 600 !important; color: #888 !important; cursor: pointer !important; border-bottom: 3px solid transparent !important; margin-bottom: -2px !important; text-transform: uppercase !important; letter-spacing: .5px !important; transition: all .15s !important; -webkit-appearance: none !important; appearance: none !important; }
#pb-app .pb-tab:hover { color: var(--pb-primary, #1A84EE) !important; background: none !important; }
#pb-app .pb-tab.active { color: var(--pb-primary, #1A84EE) !important; border-bottom-color: var(--pb-primary, #1A84EE) !important; background: none !important; }

/* ── Extras Grid (JS: .pb-extras-grid) ── */
#pb-app .pb-extras-grid { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important; gap: 14px !important; margin-bottom: 16px !important; }

/* ── Extras Card (JS: .pb-extra-card) ── */
#pb-app .pb-extra-card { background: #fff !important; border: 2px solid #e0e0e0 !important; border-radius: 12px !important; overflow: hidden !important; cursor: pointer !important; display: block !important; text-align: center !important; position: relative !important; transition: all .2s !important; }
#pb-app .pb-extra-card:hover { border-color: var(--pb-primary, #1A84EE) !important; box-shadow: 0 4px 12px color-mix(in srgb, var(--pb-primary, #1A84EE) 15%, transparent) !important; transform: translateY(-2px) !important; }
#pb-app .pb-extra-card.selected { border-color: var(--pb-primary, #1A84EE) !important; background: #eef5fd !important; }

/* ── Extras Card Image (JS: .pb-extra-img) ── */
#pb-app .pb-extra-img { width: 100% !important; height: 110px !important; object-fit: cover !important; display: block !important; }
#pb-app .pb-extra-placeholder { width: 100% !important; height: 110px !important; background: linear-gradient(135deg, color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff), color-mix(in srgb, var(--pb-primary, #1A84EE) 20%, #fff)) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 28px !important; font-weight: 700 !important; color: var(--pb-primary, #1A84EE) !important; }

/* ── Extras Card Body (JS: .pb-extra-body) ── */
#pb-app .pb-extra-body { padding: 10px !important; }
#pb-app .pb-extra-name { font-size: 13px !important; font-weight: 600 !important; color: #333 !important; margin-bottom: 2px !important; }
#pb-app .pb-extra-desc { font-size: 11px !important; color: #888 !important; margin-bottom: 4px !important; }
#pb-app .pb-extra-price { font-size: 13px !important; color: var(--pb-primary, #1A84EE) !important; font-weight: 600 !important; }

/* ── Extras Checkmark (JS: .pb-extra-check) ── */
#pb-app .pb-extra-check { position: absolute !important; top: 8px !important; right: 8px !important; width: 24px !important; height: 24px !important; border-radius: 50% !important; background: var(--pb-primary, #1A84EE) !important; color: #fff !important; font-size: 14px !important; display: none !important; align-items: center !important; justify-content: center !important; font-weight: 700 !important; box-shadow: 0 2px 6px color-mix(in srgb, var(--pb-primary, #1A84EE) 30%, transparent) !important; }
#pb-app .pb-extra-card.selected .pb-extra-check { display: flex !important; }

/* ── Ticket Controls (JS: .pb-qty-control, .pb-qty-display) ── */
#pb-app .pb-ticket-list { margin-bottom: 12px !important; }
#pb-app .pb-ticket-name { font-size: 16px !important; font-weight: 600 !important; color: #333 !important; }
#pb-app .pb-ticket-price { font-size: 14px !important; color: var(--pb-primary, #1A84EE) !important; font-weight: 500 !important; }
#pb-app .pb-ticket-desc { font-size: 12px !important; color: #888 !important; margin-top: 2px !important; }
#pb-app .pb-qty-control { display: flex !important; align-items: center !important; gap: 14px !important; }
#pb-app .pb-qty-display { font-size: 20px !important; font-weight: 700 !important; min-width: 28px !important; text-align: center !important; color: #333 !important; }

/* ── Ticket Total (JS: .pb-ticket-total) — fix spacing ── */
#pb-app .pb-ticket-total { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 10px 0 !important; font-size: 14px !important; color: #555 !important; margin-top: 8px !important; }

/* ── Calendar selected day fix — ensure text visible ── */
#pb-app .pb-cal-day.selected { background: var(--pb-primary, #1A84EE) !important; color: #fff !important; font-weight: 700 !important; border-radius: 8px !important; border-color: var(--pb-primary, #1A84EE) !important; }

/* ══════════════════════════════════════════════════════════════
   RICH VENUE CARDS
══════════════════════════════════════════════════════════════ */
#pb-app .pb-vrc { background: #fff; border: 2px solid #e8e8e8; border-radius: 16px; overflow: hidden; margin-bottom: 16px; transition: all .2s; }
#pb-app .pb-vrc:hover { border-color: var(--pb-primary, #1A84EE); box-shadow: 0 6px 24px color-mix(in srgb, var(--pb-primary, #1A84EE) 15%, transparent); }
#pb-app .pb-vrc.selected { border-color: var(--pb-primary, #1A84EE); box-shadow: 0 4px 16px color-mix(in srgb, var(--pb-primary, #1A84EE) 20%, transparent); }

/* Gallery carousel */
#pb-app .pb-vrc__gallery { position: relative; overflow: hidden; background: #f0f0f0; }
#pb-app .pb-vrc__slides { display: flex; transition: transform .3s ease; }
#pb-app .pb-vrc__slide { min-width: 100%; flex-shrink: 0; }
#pb-app .pb-vrc__slide img { width: 100%; height: auto; max-height: 350px; object-fit: contain; display: block; background: #f0f0f0; }

#pb-app .pb-vrc__arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 36px; height: 36px; border-radius: 50%; background: rgba(0,0,0,.5); color: #fff; border: none; font-size: 22px; cursor: pointer; display: flex; align-items: center; justify-content: center; z-index: 2; opacity: 0; transition: opacity .2s; }
#pb-app .pb-vrc__gallery:hover .pb-vrc__arrow { opacity: 1; }
#pb-app .pb-vrc__arrow--left { left: 8px; }
#pb-app .pb-vrc__arrow--right { right: 8px; }

#pb-app .pb-vrc__dots { position: absolute; bottom: 8px; left: 50%; transform: translateX(-50%); display: flex; gap: 5px; z-index: 2; }
#pb-app .pb-vrc__dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.5); cursor: pointer; transition: background .2s; }
#pb-app .pb-vrc__dot.active { background: #fff; }

/* Rating badge */
#pb-app .pb-vrc__badge-rating { position: absolute; top: 12px; right: 12px; background: rgba(0,0,0,.75); color: #FFD700; padding: 4px 10px; border-radius: 16px; font-size: 13px; font-weight: 700; z-index: 2; }

/* Media overlay buttons (video + photo gallery) */
#pb-app .pb-vrc__media-btns { position: absolute; bottom: 12px; left: 12px; display: flex; gap: 8px; z-index: 2; }
#pb-app .pb-vrc__media-btn { border: none; cursor: pointer; font-size: 12px; font-weight: 600; padding: 6px 14px; border-radius: 20px; display: flex; align-items: center; gap: 4px; transition: all .2s; }
#pb-app .pb-vrc__media-btn--video { background: rgba(0,0,0,.7); color: #4ade80; }
#pb-app .pb-vrc__media-btn--video:hover { background: rgba(0,0,0,.85); }
#pb-app .pb-vrc__media-btn--photos { background: rgba(255,255,255,.9); color: #333; }
#pb-app .pb-vrc__media-btn--photos:hover { background: #fff; }

/* Lightbox popup */
.pb-lightbox { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 999999; display: flex; align-items: center; justify-content: center; }
.pb-lightbox__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.85); }
.pb-lightbox__container { position: relative; max-width: 90vw; max-height: 90vh; width: 900px; z-index: 1; }
.pb-lightbox__close { position: absolute; top: -40px; right: 0; background: none; border: none; color: #fff; font-size: 32px; cursor: pointer; z-index: 2; line-height: 1; padding: 4px 8px; }
.pb-lightbox__close:hover { color: #ff6b6b; }
.pb-lightbox__video { width: 100%; aspect-ratio: 16/9; border-radius: 12px; overflow: hidden; background: #000; }
.pb-lightbox__photo { display: flex; align-items: center; justify-content: center; }
.pb-lightbox__photo img { max-width: 90vw; max-height: 85vh; border-radius: 12px; object-fit: contain; }
.pb-lightbox__arrow { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.15); border: none; color: #fff; font-size: 36px; width: 48px; height: 48px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background .2s; z-index: 2; }
.pb-lightbox__arrow:hover { background: rgba(255,255,255,.3); }
.pb-lightbox__arrow--left { left: -60px; }
.pb-lightbox__arrow--right { right: -60px; }
.pb-lightbox__counter { position: absolute; bottom: -32px; left: 50%; transform: translateX(-50%); color: rgba(255,255,255,.7); font-size: 13px; font-weight: 600; }

@media (max-width: 768px) {
    .pb-lightbox__container { max-width: 95vw; width: auto; }
    .pb-lightbox__arrow--left { left: 8px; }
    .pb-lightbox__arrow--right { right: 8px; }
    .pb-lightbox__close { top: -36px; right: 4px; }
}

/* Body */
#pb-app .pb-vrc__body { padding: 16px 20px; }
#pb-app .pb-vrc__header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; }
#pb-app .pb-vrc__name { font-size: 20px; font-weight: 700; color: #1e1e1e; margin: 0 0 4px; }
#pb-app .pb-vrc__address { font-size: 13px; color: #888; display: flex; align-items: center; gap: 4px; }

/* Action buttons (Maps, Food) */
#pb-app .pb-vrc__action-btns { display: flex; gap: 8px; flex-shrink: 0; }
#pb-app .pb-vrc__action-btn { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 6px 10px; border: 1px solid #e0e0e0; border-radius: 8px; text-decoration: none; color: #555; font-size: 10px; font-weight: 600; transition: all .2s; }
#pb-app .pb-vrc__action-btn:hover { border-color: var(--pb-primary); color: var(--pb-primary); }

/* Amenities */
#pb-app .pb-vrc__amenities { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; padding: 10px 0; border-top: 1px solid #f0f0f0; }
#pb-app .pb-vrc__amenity { font-size: 13px; color: #555; white-space: nowrap; }

/* Pricing text */
#pb-app .pb-vrc__pricing { font-size: 15px; font-weight: 700; color: var(--pb-primary); margin-bottom: 12px; }

/* Contact buttons */
#pb-app .pb-vrc__contacts { display: flex; gap: 8px; margin-bottom: 14px; }
#pb-app .pb-vrc__wa-btn, #pb-app .pb-vrc__call-btn { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: 8px; font-size: 13px; font-weight: 600; text-decoration: none; transition: all .2s; }
#pb-app .pb-vrc__wa-btn { background: #25D366; color: #fff; }
#pb-app .pb-vrc__wa-btn:hover { background: #1da851; }
#pb-app .pb-vrc__call-btn { background: #f0f0f0; color: #333; border: 1px solid #ddd; }
#pb-app .pb-vrc__call-btn:hover { border-color: var(--pb-primary); color: var(--pb-primary); }

/* Select button */
#pb-app .pb-vrc__select-btn { width: 100%; padding: 12px; border: 2px solid var(--pb-primary); background: #fff; color: var(--pb-primary); border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer; transition: all .2s; text-transform: uppercase; letter-spacing: .5px; }
#pb-app .pb-vrc__select-btn:hover { background: var(--pb-primary); color: #fff; }
#pb-app .pb-vrc__select-btn.selected { background: var(--pb-primary); color: #fff; }

/* ══════════════════════════════════════════════════════════════
   FLOATING BUTTONS (WhatsApp + Call)
══════════════════════════════════════════════════════════════ */
#pb-app .pb-float-btns { position: fixed; bottom: 24px; right: 24px; display: flex; flex-direction: column; gap: 12px; z-index: 9999; }
#pb-app .pb-float-btn { width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 16px rgba(0,0,0,.25); text-decoration: none; transition: transform .2s; }
#pb-app .pb-float-btn:hover { transform: scale(1.1); }
#pb-app .pb-float-call { background: var(--pb-primary, #1A84EE); }
#pb-app .pb-float-wa { background: #25D366; }

/* ══════════════════════════════════════════════════════════════
   COUPON SECTION
══════════════════════════════════════════════════════════════ */
#pb-app .pb-coupon-section { padding: 16px 0; border-top: 1px solid #f0f0f0; margin-top: 8px; }

/* ══════════════════════════════════════════════════════════════
   WHATSAPP SHARE BUTTON
══════════════════════════════════════════════════════════════ */
#pb-app .pb-btn-whatsapp { background: #25D366 !important; border-color: #25D366 !important; color: #fff !important; }
#pb-app .pb-btn-whatsapp:hover { background: #1da851 !important; }

/* ══════════════════════════════════════════════════════════════
   SINGLE-PAGE BOOKING FORM
══════════════════════════════════════════════════════════════ */
#pb-app .pb-booking-section { margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid #f0f0f0; }
#pb-app .pb-booking-section:last-child { border-bottom: none; }
#pb-app .pb-booking-section h3 { font-size: 17px; font-weight: 700; color: #1e1e1e; margin: 0 0 14px; }

#pb-app .pb-field { margin-bottom: 14px; }
#pb-app .pb-field label { display: block; font-size: 13px; font-weight: 600; color: #555; margin-bottom: 6px; }
#pb-app .pb-field input, #pb-app .pb-field select, #pb-app .pb-field textarea { width: 100%; padding: 10px 14px; border: 1.5px solid #e0e0e0; border-radius: 8px; font-size: 14px; box-sizing: border-box; transition: border-color .2s; }
#pb-app .pb-field input:focus, #pb-app .pb-field select:focus { border-color: var(--pb-primary); outline: none; }

#pb-app .pb-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

/* Occasion pills (text-only) */
#pb-app .pb-occasion-pills { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; }
#pb-app .pb-pill { padding: 8px 16px; border-radius: 20px; border: 1.5px solid #e0e0e0; background: #fff; font-size: 13px; font-weight: 500; color: #555; cursor: pointer; transition: all .2s; }
#pb-app .pb-pill:hover { border-color: var(--pb-primary); color: var(--pb-primary); }
#pb-app .pb-pill.active { background: var(--pb-primary); border-color: var(--pb-primary); color: #fff; }

/* Occasion cards (with images) */
#pb-app .pb-occasion-card { display: flex; flex-direction: column; align-items: center; width: 100px; padding: 10px 8px; border: 2px solid #e8e8e8; border-radius: 12px; background: #fff; cursor: pointer; transition: all .2s; text-align: center; }
#pb-app .pb-occasion-card:hover { border-color: var(--pb-primary); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.08); }
#pb-app .pb-occasion-card.active { border-color: var(--pb-primary); background: color-mix(in srgb, var(--pb-primary) 8%, #fff); }
#pb-app .pb-occasion-card__img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; margin-bottom: 6px; }
#pb-app .pb-occasion-card__name { font-size: 11px; font-weight: 600; color: #333; line-height: 1.2; text-transform: none; }

/* Booking overview header */
#pb-app .pb-booking-overview { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: color-mix(in srgb, var(--pb-primary, #1A84EE) 8%, #fff); border-radius: 10px; margin-bottom: 20px; }
#pb-app .pb-booking-overview__name { font-size: 16px; font-weight: 700; color: #1e1e1e; }
#pb-app .pb-booking-overview__loc { font-size: 13px; color: #888; }

/* Book Now large button */
#pb-app .pb-btn-lg { padding: 14px 32px !important; font-size: 16px !important; }

/* Booking actions bar */
#pb-app .pb-booking-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 24px; padding-top: 16px; border-top: 1px solid #f0f0f0; gap: 12px; }

/* Time slot pills (horizontal scroll for inline slots) */
#pb-app .pb-slot-pills { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
#pb-app .pb-slot-pill { padding: 8px 14px; border: 1.5px solid #e0e0e0; border-radius: 8px; font-size: 12px; color: #555; cursor: pointer; text-align: center; white-space: nowrap; transition: all .2s; background: #fff; }
#pb-app .pb-slot-pill:hover { border-color: var(--pb-primary); color: var(--pb-primary); }
#pb-app .pb-slot-pill.selected { background: var(--pb-primary); border-color: var(--pb-primary); color: #fff; }
#pb-app .pb-slot-pill.booked { opacity: .4; cursor: not-allowed; }

/* Extras in booking page - more compact */
#pb-app .pb-booking-extras-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }

/* Slots available badge on theatre cards */
#pb-app .pb-vrc__slots-badge { display: inline-block; padding: 4px 12px; background: #e8f5e9; color: #2e7d32; border-radius: 16px; font-size: 12px; font-weight: 600; margin-bottom: 10px; }

/* Responsive */
@media (max-width: 640px) {
    #pb-app .pb-form-grid { grid-template-columns: 1fr !important; }
    #pb-app .pb-venue-grid { grid-template-columns: repeat(2, 1fr) !important; }
    #pb-app .pb-venue-grid--single, #pb-app .pb-venue-grid--rich { grid-template-columns: 1fr !important; }
    #pb-app .pb-cal-day { padding: 8px 2px !important; font-size: 13px !important; }
    #pb-app .pb-slots-grid { grid-template-columns: repeat(2, 1fr) !important; }
    #pb-app .pb-extras-grid { grid-template-columns: repeat(2, 1fr) !important; }
    #pb-app .pb-card { padding: 16px !important; }
    #pb-app .pb-vrc { border-radius: 12px; }
    #pb-app .pb-vrc__slide img { max-height: 250px; }
    #pb-app .pb-vrc__body { padding: 14px 16px; }
    #pb-app .pb-vrc__header { flex-direction: column; gap: 8px; }
    #pb-app .pb-vrc__name { font-size: 18px; }
    #pb-app .pb-vrc__action-btns { flex-direction: row; align-self: flex-start; }
    #pb-app .pb-vrc__amenities { gap: 6px 12px; }
    #pb-app .pb-vrc__amenity { font-size: 12px; }
    #pb-app .pb-vrc__contacts { flex-wrap: wrap; }
    #pb-app .pb-vrc__wa-btn, #pb-app .pb-vrc__call-btn { flex: 1; justify-content: center; }
    #pb-app .pb-vrc__select-btn { font-size: 14px; padding: 10px; }
    #pb-app .pb-vrc__pricing { font-size: 14px; }
    #pb-app .pb-float-btns { bottom: 16px; right: 16px; }
    #pb-app .pb-float-btn { width: 48px; height: 48px; }
    #pb-app .pb-field-row { grid-template-columns: 1fr; }
    #pb-app .pb-booking-extras-grid { grid-template-columns: repeat(2, 1fr); }
    #pb-app .pb-booking-actions { flex-direction: column-reverse; }
    #pb-app .pb-booking-actions .pb-btn { width: 100%; justify-content: center; text-align: center; }
    #pb-app .pb-occasion-pills { gap: 6px; }
    #pb-app .pb-pill { padding: 6px 12px; font-size: 12px; }
    #pb-app .pb-slot-pills { gap: 6px; }
    #pb-app .pb-slot-pill { padding: 6px 10px; font-size: 11px; }
    #pb-app .pb-booking-section h3 { font-size: 15px; }
}
