.sp-bookings-page{max-width:720px;padding-bottom:80px}.sp-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.sp-tab-strip{display:flex;gap:4px;border-bottom:1px solid var(--sp-border);margin-bottom:24px}.sp-tab{border:none;background:none;padding:12px 20px;font-size:14px;font-weight:600;color:var(--sp-text-muted);cursor:pointer;font-family:Inter,sans-serif;border-bottom:2px solid transparent;transition:all var(--sp-transition-fast);display:flex;align-items:center;gap:8px}.sp-tab:hover{color:var(--sp-text-primary)}.sp-tab.active{color:var(--sp-dark);border-bottom-color:var(--sp-dark)}.sp-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;padding:1px 6px;background:var(--sp-surface-raised);border-radius:var(--sp-radius-full);font-size:11px;font-weight:700}.sp-tab.active .sp-tab-count{background:var(--sp-brand);color:var(--sp-white)}.sp-booking-card{background:var(--sp-white);border:1px solid var(--sp-border);border-radius:var(--sp-radius-lg);padding:18px;margin-bottom:12px;display:flex;gap:16px;box-shadow:var(--sp-shadow-card);transition:all var(--sp-transition-fast);animation:sp-fade-in .3s ease}.sp-booking-card:hover{border-color:var(--sp-border-strong);box-shadow:var(--sp-shadow-md)}@keyframes sp-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sp-booking-group{position:relative;margin-bottom:12px;animation:sp-fade-in .3s ease}.sp-booking-group:before,.sp-booking-group:after{content:"";position:absolute;left:6px;right:6px;bottom:-5px;height:16px;background:var(--sp-white);border:1px solid var(--sp-border);border-radius:var(--sp-radius-lg);box-shadow:var(--sp-shadow-card);z-index:0;transition:opacity var(--sp-transition-fast),transform var(--sp-transition-fast)}.sp-booking-group:after{left:12px;right:12px;bottom:-10px}.sp-booking-group.expanded:before,.sp-booking-group.expanded:after{opacity:0}.sp-booking-group-header{position:relative;z-index:1;display:block;width:100%;padding:0;margin:0;border:none;background:none;cursor:pointer;text-align:left;font-family:Inter,sans-serif}.sp-booking-group-stack{display:flex;gap:16px;align-items:center;background:var(--sp-white);border:1px solid var(--sp-border);border-radius:var(--sp-radius-lg);padding:18px;box-shadow:var(--sp-shadow-card);transition:all var(--sp-transition-fast)}.sp-booking-group-header:hover .sp-booking-group-stack{border-color:var(--sp-border-strong);box-shadow:var(--sp-shadow-md)}.sp-booking-group-aside{flex-shrink:0;display:flex;align-items:center;gap:10px;align-self:stretch}.sp-booking-group-count{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:26px;padding:0 8px;background:var(--sp-brand);color:var(--sp-white);border-radius:var(--sp-radius-full);font-size:13px;font-weight:700;line-height:1}.sp-booking-group-chevron{width:18px;height:18px;color:var(--sp-text-muted);flex-shrink:0;transition:transform var(--sp-transition-fast)}.sp-booking-group.expanded .sp-booking-group-chevron{transform:rotate(180deg)}.sp-booking-group-items{display:none;position:relative;z-index:1;padding-left:16px;margin-top:10px;border-left:2px solid var(--sp-border)}.sp-booking-group.expanded .sp-booking-group-items{display:block}.sp-booking-group-items .sp-booking-card:last-child{margin-bottom:0}.sp-booking-date{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;width:70px;padding:12px 0;border-right:1px solid var(--sp-border);text-align:center}.sp-booking-date-month{font-size:11px;font-weight:600;color:var(--sp-text-muted);text-transform:uppercase;letter-spacing:.5px}.sp-booking-date-day{font-family:Inter,-apple-system,sans-serif;font-size:32px;font-weight:700;color:var(--sp-dark);line-height:1;margin-top:2px;letter-spacing:-1px}.sp-booking-date-weekday{font-size:11px;color:var(--sp-text-muted);margin-top:4px}.sp-booking-info{flex:1;min-width:0}.sp-booking-title{font-size:16px;font-weight:600;color:var(--sp-text-primary);margin-bottom:4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sp-booking-meta{font-size:13px;color:var(--sp-text-muted);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.sp-booking-meta-item{display:inline-flex;align-items:center;gap:4px}.sp-booking-meta-item svg{width:14px;height:14px;flex-shrink:0}.sp-booking-ref{font-family:JetBrains Mono,Courier New,monospace;font-size:11px;color:var(--sp-text-muted);margin-top:6px;letter-spacing:.5px}.sp-booking-actions{flex-shrink:0;display:flex;flex-direction:column;gap:6px;align-items:flex-end;justify-content:space-between}.sp-booking-actions .sp-btn{padding:6px 12px;font-size:12px}.sp-status-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--sp-radius-full);text-transform:uppercase;letter-spacing:.5px}.sp-status-badge.RESERVED{background:var(--sp-brand-soft);color:var(--sp-brand-dark)}.sp-status-badge.BOOKED,.sp-status-badge.CHECKED_IN{background:var(--sp-success-soft);color:var(--sp-success)}.sp-status-badge.CANCELLED{background:var(--sp-surface-raised);color:var(--sp-text-muted)}.sp-status-badge.LATE_CANCEL{background:var(--sp-warning-soft);color:var(--sp-warning)}.sp-status-badge.NO_SHOW{background:var(--sp-danger-soft);color:var(--sp-danger)}.sp-status-badge.WAITLIST{background:var(--sp-brand-soft);color:var(--sp-brand-dark)}.sp-waitlist-position{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--sp-radius-full);background:var(--sp-brand-soft);color:var(--sp-brand-dark);font-size:12px;font-weight:600}.sp-waitlist-position-num{font-family:Inter,-apple-system,sans-serif;font-size:15px;font-weight:700;line-height:1}.sp-filter-chips{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.sp-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;font-size:12px;font-weight:600;border:1.5px solid var(--sp-border);border-radius:var(--sp-radius-full);background:transparent;color:var(--sp-text-secondary);cursor:pointer;font-family:Inter,sans-serif;transition:all .18s ease}.sp-chip:hover:not(.sp-chip-active){border-color:var(--sp-brand-light, #c9916a);color:var(--sp-brand)}.sp-chip-active{border-color:var(--sp-brand, #9b6a4f);background:var(--sp-brand, #9b6a4f);color:var(--sp-white)}.sp-chip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.sp-paid-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--sp-radius-full);background:#0596691f;color:#059669;text-transform:uppercase;letter-spacing:.5px}.sp-empty-state{text-align:center;padding:60px 24px;color:var(--sp-text-muted)}.sp-empty-state-icon{width:64px;height:64px;margin:0 auto 16px;background:var(--sp-surface-raised);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--sp-text-muted)}.sp-empty-state-icon svg{width:32px;height:32px}.sp-empty-state-title{font-size:16px;font-weight:600;color:var(--sp-text-primary);margin-bottom:4px}.sp-dialog-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:sp-fade-in .2s ease}.sp-dialog{background:var(--sp-white);border-radius:var(--sp-radius-lg);padding:24px;max-width:520px;width:100%;box-shadow:var(--sp-shadow-lg)}.sp-dialog-actions{display:flex;flex-wrap:wrap;gap:8px;row-gap:8px;justify-content:flex-end}.sp-seat-cancel{margin-bottom:16px;padding:14px 16px;background:var(--sp-surface-raised);border:1px solid var(--sp-border);border-radius:var(--sp-radius-md)}.sp-seat-cancel-label{display:block;font-size:13px;font-weight:600;color:var(--sp-text-primary);margin-bottom:8px}.sp-seat-cancel-controls{display:flex;align-items:center;gap:8px}.sp-seat-step{width:34px;height:34px;flex-shrink:0;border:1px solid var(--sp-border);background:var(--sp-white);border-radius:var(--sp-radius-md);font-size:18px;font-weight:700;line-height:1;color:var(--sp-text-primary);cursor:pointer;transition:all var(--sp-transition-fast)}.sp-seat-step:hover:not(:disabled){border-color:var(--sp-brand);color:var(--sp-brand)}.sp-seat-step:disabled{opacity:.4;cursor:not-allowed}.sp-seat-cancel-input{width:64px;height:34px;text-align:center;border:1px solid var(--sp-border);border-radius:var(--sp-radius-md);font-size:15px;font-weight:600;font-family:Inter,sans-serif;color:var(--sp-text-primary);background:var(--sp-white)}.sp-seat-cancel-input:focus{outline:none;border-color:var(--sp-brand);box-shadow:0 0 0 3px var(--sp-brand-soft)}.sp-seat-cancel-of{font-size:13px;color:var(--sp-text-muted);margin-left:4px}@media(max-width:768px){.sp-bookings-page{padding-bottom:calc(var(--sp-bottomnav-height) + 32px)}.sp-page-header{flex-direction:column;align-items:stretch}.sp-booking-card{flex-direction:column;gap:12px;padding:16px}.sp-booking-date{flex-direction:row;width:auto;border-right:none;border-bottom:1px solid var(--sp-border);padding:0 0 8px;gap:8px;justify-content:flex-start}.sp-booking-date-day{font-size:22px}.sp-booking-actions{flex-direction:row-reverse;align-items:stretch}.sp-booking-actions .sp-btn{flex:1}}.sp-reschedule-dialog{max-width:700px;max-height:85vh;display:flex;flex-direction:column;padding:0;overflow:hidden}.sp-reschedule-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 24px 0}.sp-reschedule-subtitle{font-size:13px;color:var(--sp-text-muted);margin-top:4px;margin-bottom:0}.sp-reschedule-close{flex-shrink:0;width:32px;height:32px;border:none;background:var(--sp-surface-raised);border-radius:var(--sp-radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--sp-text-muted);transition:all var(--sp-transition-fast)}.sp-reschedule-close:hover{background:var(--sp-border);color:var(--sp-text-primary)}.sp-reschedule-close svg{width:16px;height:16px}.sp-reschedule-filters{display:flex;align-items:flex-end;gap:12px;padding:16px 24px;border-bottom:1px solid var(--sp-border);flex-wrap:wrap;background:var(--sp-surface-raised)}.sp-reschedule-filter-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:130px}.sp-reschedule-label{font-size:11px;font-weight:600;color:var(--sp-text-muted);text-transform:uppercase;letter-spacing:.5px}.sp-reschedule-date-input{height:38px;padding:0 12px;border:1px solid var(--sp-border);border-radius:var(--sp-radius-md);font-size:14px;font-family:Inter,sans-serif;color:var(--sp-text-primary);background:var(--sp-white);width:100%;cursor:pointer;transition:border-color var(--sp-transition-fast),box-shadow var(--sp-transition-fast)}.sp-reschedule-date-input:focus{outline:none;border-color:var(--sp-brand);box-shadow:0 0 0 3px var(--sp-brand-soft)}.sp-reschedule-filter-sep{font-size:18px;color:var(--sp-text-muted);padding-bottom:8px;flex-shrink:0;line-height:38px}.sp-reschedule-session-list{flex:1;overflow-y:auto;padding:16px 24px 24px;display:flex;flex-direction:column;gap:0}.sp-reschedule-loading{display:flex;flex-direction:column;gap:8px}.sp-reschedule-empty{text-align:center;padding:48px 24px;color:var(--sp-text-muted);display:flex;flex-direction:column;align-items:center;font-size:14px;font-weight:500}.sp-reschedule-date-group{margin-bottom:20px}.sp-reschedule-date-label{font-size:11px;font-weight:700;color:var(--sp-text-muted);text-transform:uppercase;letter-spacing:.6px;padding:0 2px 8px;border-bottom:1px solid var(--sp-border);margin-bottom:10px}.sp-reschedule-session-btn{display:flex;align-items:center;gap:14px;width:100%;padding:12px 14px;border:1px solid var(--sp-border);border-radius:var(--sp-radius-md);background:var(--sp-white);cursor:pointer;text-align:left;transition:all var(--sp-transition-fast);color:var(--sp-text-primary);font-family:Inter,sans-serif;margin-bottom:6px}.sp-reschedule-session-btn:last-child{margin-bottom:0}.sp-reschedule-session-btn:hover{border-color:var(--sp-brand);background:var(--sp-brand-soft);box-shadow:0 2px 8px #0000000f}.sp-reschedule-session-btn.is-loading{opacity:.6;pointer-events:none}.sp-reschedule-session-time{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:58px;flex-shrink:0;font-size:14px;font-weight:700;color:var(--sp-brand-dark);padding-right:14px;border-right:1px solid var(--sp-border)}.sp-reschedule-session-time svg{width:13px;height:13px;color:var(--sp-text-muted)}.sp-reschedule-session-info{flex:1;min-width:0}.sp-reschedule-session-name{font-size:14px;font-weight:600;color:var(--sp-text-primary);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-reschedule-session-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--sp-text-muted);flex-wrap:wrap}.sp-reschedule-spots{display:inline-flex;align-items:center;padding:2px 8px;background:var(--sp-success-soft);color:var(--sp-success);border-radius:var(--sp-radius-full);font-size:11px;font-weight:600}.sp-reschedule-session-arrow{width:16px;height:16px;color:var(--sp-text-muted);flex-shrink:0;transition:transform var(--sp-transition-fast),color var(--sp-transition-fast)}.sp-reschedule-session-btn:hover .sp-reschedule-session-arrow{transform:translate(3px);color:var(--sp-brand)}@media(max-width:600px){.sp-reschedule-dialog{max-height:92vh}.sp-reschedule-filters{gap:8px}.sp-reschedule-filter-sep{display:none}.sp-reschedule-filter-group{min-width:calc(50% - 8px)}.sp-reschedule-session-time{min-width:48px;font-size:12px}}.sp-reschedule-confirm-overlay{position:absolute;inset:0;border-radius:var(--sp-radius-lg);background:#fffffff5;backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 28px;text-align:center;animation:sp-confirm-slide-up .22s cubic-bezier(.34,1.56,.64,1) both;z-index:10}@keyframes sp-confirm-slide-up{0%{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.sp-reschedule-confirm-icon{width:52px;height:52px;border-radius:50%;background:var(--sp-brand-soft);color:var(--sp-brand-dark);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.sp-reschedule-confirm-icon svg{width:26px;height:26px}.sp-reschedule-confirm-title{font-size:17px;font-weight:700;color:var(--sp-text-primary);margin-bottom:6px}.sp-reschedule-confirm-subtitle{font-size:13px;color:var(--sp-text-muted);margin-bottom:20px;line-height:1.5}.sp-reschedule-confirm-card{width:100%;max-width:380px;background:var(--sp-surface-raised);border:1px solid var(--sp-border);border-radius:var(--sp-radius-md);padding:14px 18px;margin-bottom:24px;text-align:left}.sp-reschedule-confirm-card-name{font-size:15px;font-weight:700;color:var(--sp-text-primary);margin-bottom:6px}.sp-reschedule-confirm-card-meta{font-size:13px;color:var(--sp-text-muted);display:flex;flex-direction:column;gap:4px}.sp-reschedule-confirm-card-meta span{display:flex;align-items:center;gap:6px}.sp-reschedule-confirm-card-meta svg{width:13px;height:13px;flex-shrink:0}.sp-reschedule-confirm-actions{display:flex;gap:10px;width:100%;max-width:380px}.sp-reschedule-confirm-actions .sp-btn{flex:1}
