/*
 * Sierra Collective — My bookings page styles
 */

.page { max-width: 800px; margin: 0 auto; padding: 56px 48px 96px; }

.filters { display: flex; align-items: center; gap: 8px; margin-bottom: 36px; flex-wrap: wrap; }
.filter-btn { padding: 5px 14px; border: 1px solid var(--border2); background: none; font-family: var(--font-body); font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); cursor: crosshair; transition: all 0.15s; }
.filter-btn:hover { border-color: var(--amber-dim); color: var(--amber); }
.filter-btn.active { border-color: var(--amber); color: var(--amber); background: rgba(200,134,46,0.08); }

.bookings-list { display: flex; flex-direction: column; gap: 1px; background: var(--border); }

.booking-row {
  background: var(--bg2); padding: 22px 28px;
  display: flex; align-items: flex-start; gap: 20px; position: relative;
}
.booking-row::before {
  content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 100%;
}
.booking-row.pending::before { background: var(--amber-dim); }
.booking-row.confirmed::before { background: var(--green); }
.booking-row.cancelled::before { background: var(--red); }

.booking-date {
  flex-shrink: 0; width: 60px; text-align: center;
  border: 1px solid var(--border2); padding: 8px 6px; background: var(--bg3);
}
.booking-month { font-size: 9px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--amber-dim); }
.booking-day { font-family: var(--font-display); font-size: 24px; line-height: 1; color: var(--text); }
.booking-time { font-size: 10px; font-weight: 300; color: var(--muted); margin-top: 2px; }

.booking-body { flex: 1; min-width: 0; }
.booking-title { font-family: var(--font-display); font-size: 18px; letter-spacing: 0.02em; text-transform: uppercase; margin-bottom: 5px; }
.booking-meta { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; margin-bottom: 4px; }
.booking-status-badge {
  font-size: 9px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 2px 8px; border: 1px solid;
}
.booking-status-badge.pending { color: var(--amber); border-color: var(--amber-dim); }
.booking-status-badge.confirmed { color: var(--green-bright); border-color: rgba(74,140,92,0.4); }
.booking-status-badge.cancelled { color: var(--muted); border-color: var(--border2); }
.booking-instructor { font-size: 11px; font-weight: 300; color: var(--muted); }
.booking-type { font-size: 11px; font-weight: 300; color: var(--muted); }
.booking-notes { font-size: 12px; font-weight: 300; color: var(--muted); margin-top: 4px; font-style: italic; }

.booking-actions { flex-shrink: 0; display: flex; flex-direction: column; gap: 6px; }

.empty-state { text-align: center; padding: 80px 0; }
.empty-state h3 { font-family: var(--font-display); font-size: 24px; text-transform: uppercase; margin-bottom: 8px; }
.empty-state p { font-size: 13px; color: var(--muted); }

@media (max-width: 600px) {
  .page { padding: 36px 24px 64px; }
  .booking-row { flex-direction: column; gap: 14px; }
}
