/* ============================================================
   ELEVATE BOOKING — Pages
   Styles for the booking product section (marketing, demo, dashboard).
   Depends on styles.css tokens.
   ============================================================ */

/* ---------- Shared page chrome ---------- */
.booking-page { background: var(--bg); color: var(--text); }
.booking-page a { color: inherit; }
.bk-container { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--gutter); }

/* A sub-nav strip that reinforces "you're in the Booking product" */
.booking-subnav {
  position: sticky; top: 4rem; z-index: 290;
  background: color-mix(in oklab, var(--bg) 85%, transparent);
  backdrop-filter: saturate(1.2) blur(10px);
  -webkit-backdrop-filter: saturate(1.2) blur(10px);
  border-bottom: 1px solid var(--border);
}
.booking-subnav .bar {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 var(--gutter);
  height: 3.25rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.booking-subnav .crumbs { color: var(--text-muted); font-size: var(--fs-body-sm); display: flex; align-items: center; gap: 0.5rem; }
.booking-subnav .crumbs strong { color: var(--text); font-weight: 500; }
.booking-subnav .links { display: flex; align-items: center; gap: 1.5rem; font-size: var(--fs-body-sm); color: var(--text-muted); }
.booking-subnav .links a:hover { color: var(--text); }

/* ---------- Marketing page (hero + value props + pricing) ---------- */
.bk-hero { padding: clamp(4rem, 10vw, 7.5rem) var(--gutter) clamp(3rem, 8vw, 5rem); }
.bk-hero .kicker {
  font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted);
}
.bk-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 7vw, var(--fs-display-xxl));
  line-height: 1.03;
  letter-spacing: -0.025em;
  font-weight: 400;
  margin-top: 1rem;
  max-width: 20ch;
}
.bk-hero .lede {
  margin-top: 1.25rem;
  font-size: clamp(1.0625rem, 1.5vw, var(--fs-body-lg));
  color: var(--text-muted);
  max-width: 56ch;
}
.bk-hero .cta { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: 0.75rem; }

/* Hero preview cards (admin + widget) */
.bk-preview {
  margin-top: 4rem;
  display: grid; grid-template-columns: 3fr 2fr; gap: 1rem;
  max-width: var(--max-w); margin-left: auto; margin-right: auto;
}
.bk-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden;
}
.bk-card .cardbar {
  padding: 0.75rem 1.25rem;
  border-bottom: 1px solid var(--border);
  font-size: var(--fs-body-sm);
  color: var(--text-muted);
  display: flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-mono);
}
.bk-card .cardbar .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--success); }
.bk-card .body { padding: 1.5rem; }

.bk-today-headline { font-family: var(--font-display); font-size: var(--fs-h1); letter-spacing: -0.02em; font-weight: 400; margin-top: 0.25rem; }
.bk-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.5rem 0.75rem; border-radius: 4px;
}
.bk-row:hover { background: var(--surface-2); }
.bk-row .t { font-family: var(--font-mono); color: var(--text-muted); width: 3rem; font-size: var(--fs-body-sm); }
.bk-row .who { font-weight: 500; flex: 1; margin-left: 1rem; }
.bk-row .what { color: var(--text-muted); font-size: var(--fs-body-sm); }

.bk-widget-step {
  font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted);
}
.bk-widget h3 { font-family: var(--font-display); font-size: var(--fs-h2); letter-spacing: -0.02em; font-weight: 400; margin-top: 0.25rem; }
.bk-widget .item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem; border: 1px solid var(--border); border-radius: var(--radius);
  margin-top: 0.75rem; background: var(--surface);
}
.bk-widget .item.selected {
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 6%, var(--surface));
}
.bk-widget .item .name { font-weight: 500; }
.bk-widget .item .meta { color: var(--text-muted); font-size: var(--fs-body-sm); }
.bk-widget .item .price { font-family: var(--font-mono); font-size: var(--fs-body-sm); }

@media (max-width: 900px) { .bk-preview { grid-template-columns: 1fr; } }

/* Value props grid (editorial) */
.bk-valueprops { padding: clamp(4rem, 8vw, 6rem) var(--gutter); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.bk-valueprops .header { max-width: 44rem; margin-bottom: 3rem; }
.bk-valueprops h2 { font-family: var(--font-display); font-size: clamp(1.875rem, 4vw, var(--fs-display-lg)); line-height: 1.1; letter-spacing: -0.02em; font-weight: 400; }
.bk-valueprops .grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}
.bk-valueprops .grid > div {
  flex: 1 1 280px;
  max-width: 360px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.75rem;
}
.bk-valueprops .grid h3 { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: 500; letter-spacing: -0.01em; }
.bk-valueprops .grid p { color: var(--text-muted); margin-top: 0.5rem; font-size: var(--fs-body); }

/* Verticals */
.bk-verticals { padding: clamp(4rem, 8vw, 6rem) var(--gutter); background: var(--surface-2); border-bottom: 1px solid var(--border); }
.bk-verticals .header { max-width: 44rem; margin-bottom: 3rem; }
.bk-verticals h2 { font-family: var(--font-display); font-size: clamp(1.875rem, 4vw, var(--fs-display-lg)); line-height: 1.1; letter-spacing: -0.02em; font-weight: 400; }
.bk-verticals .lede { color: var(--text-muted); margin-top: 1rem; max-width: 50ch; font-size: var(--fs-body-lg); }
.bk-verticals .grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.25rem; }
.bk-verticals .grid > article {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.75rem;
}
.bk-verticals .grid h3 { font-family: var(--font-display); font-size: var(--fs-h2); letter-spacing: -0.02em; font-weight: 400; }
.bk-verticals .grid .tag { font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.bk-verticals .grid ul { margin-top: 1rem; display: flex; flex-direction: column; gap: 0.5rem; }
.bk-verticals .grid li { position: relative; padding-left: 1.125rem; font-size: var(--fs-body-sm); color: var(--text-muted); }
.bk-verticals .grid li::before { content: ""; position: absolute; left: 0; top: 0.55rem; width: 4px; height: 4px; background: var(--accent); border-radius: 50%; }
.bk-verticals .grid .head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }

/* Pricing */
.bk-pricing { padding: clamp(4rem, 8vw, 6rem) var(--gutter); border-bottom: 1px solid var(--border); }
.bk-pricing .header { max-width: 44rem; margin-bottom: 3rem; }
.bk-pricing h2 { font-family: var(--font-display); font-size: clamp(1.875rem, 4vw, var(--fs-display-lg)); line-height: 1.1; letter-spacing: -0.02em; font-weight: 400; }
.bk-pricing .tiers { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1.25rem; }
.bk-pricing .tier {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 2rem;
  display: flex; flex-direction: column;
}
.bk-pricing .tier.highlight { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.bk-pricing .tier .name { font-family: var(--font-display); font-size: var(--fs-h2); letter-spacing: -0.02em; font-weight: 400; }
.bk-pricing .tier .price { font-family: var(--font-display); font-size: var(--fs-display-lg); letter-spacing: -0.02em; font-weight: 400; margin-top: 1rem; line-height: 1; }
.bk-pricing .tier .price .per { font-size: var(--fs-body-sm); color: var(--text-muted); font-family: var(--font-sans); margin-left: 0.5rem; }
.bk-pricing .tier .tagline { color: var(--text-muted); font-size: var(--fs-body-sm); margin-top: 0.25rem; }
.bk-pricing .tier ul { margin-top: 1.25rem; flex: 1; display: flex; flex-direction: column; gap: 0.625rem; }
.bk-pricing .tier li { position: relative; padding-left: 1.25rem; font-size: var(--fs-body-sm); }
.bk-pricing .tier li::before {
  content: ""; position: absolute; left: 0; top: 0.55rem;
  width: 6px; height: 3px; border-left: 1.5px solid var(--accent); border-bottom: 1.5px solid var(--accent);
  transform: rotate(-45deg); border-radius: 0;
}
.bk-pricing .tier .btn { margin-top: 1.5rem; }

/* Closing CTA */
.bk-cta-close { padding: clamp(5rem, 10vw, 8rem) var(--gutter); background: var(--surface-2); text-align: center; }
.bk-cta-close h2 { font-family: var(--font-display); font-size: clamp(2rem, 5vw, var(--fs-display-lg)); line-height: 1.08; letter-spacing: -0.02em; font-weight: 400; max-width: 32ch; margin: 0 auto; }
.bk-cta-close p { color: var(--text-muted); max-width: 48ch; margin: 1rem auto 0; font-size: var(--fs-body-lg); }
.bk-cta-close .cta { margin-top: 2rem; display: flex; justify-content: center; gap: 0.75rem; flex-wrap: wrap; }

/* ---------- Demo tab bar ---------- */
.bk-demobar {
  position: sticky; top: 4rem; z-index: 290;
  background: color-mix(in oklab, var(--surface) 85%, transparent);
  backdrop-filter: saturate(1.2) blur(10px);
  -webkit-backdrop-filter: saturate(1.2) blur(10px);
  border-bottom: 1px solid var(--border);
}
.bk-demobar .bar {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 var(--gutter);
  height: 3.5rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.bk-demobar .back { color: var(--text-muted); font-size: var(--fs-body-sm); }
.bk-demobar .back:hover { color: var(--text); }
.bk-demobar .url { font-family: var(--font-mono); font-size: var(--fs-body-sm); color: var(--text-muted); display: flex; align-items: center; gap: 0.5rem; }
.bk-demobar .url .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--success); }

.bk-tabgroup {
  display: inline-flex; padding: 4px; gap: 2px;
  background: var(--surface-2);
  border: 1px solid var(--border); border-radius: var(--radius);
}
.bk-tabgroup button {
  height: 2rem; padding: 0 0.75rem;
  border-radius: 4px;
  font-size: var(--fs-body-sm); font-weight: 500; color: var(--text-muted);
  background: transparent; border: none; cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast);
}
.bk-tabgroup button:hover { color: var(--text); }
.bk-tabgroup button.active { background: var(--surface); color: var(--text); box-shadow: 0 1px 3px rgba(0,0,0,0.04); }

/* ---------- Booking widget (customer flow) ---------- */
.bk-flow { max-width: 42rem; margin: 0 auto; padding: clamp(2.5rem, 6vw, 4rem) 1.5rem; }
.bk-brand { text-align: center; margin-bottom: 2rem; }
.bk-brand .chip {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.35rem 0.75rem; border: 1px solid var(--border); border-radius: 999px;
  background: var(--surface);
}
.bk-brand .chip .logo {
  width: 20px; height: 20px; border-radius: 4px; background: var(--accent); color: var(--accent-fg);
  display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 600;
}
.bk-brand h1 { font-family: var(--font-display); font-size: var(--fs-display-lg); font-weight: 400; letter-spacing: -0.02em; margin-top: 1rem; }
.bk-brand p { color: var(--text-muted); margin-top: 0.5rem; }

.bk-progress { display: flex; gap: 6px; max-width: 28rem; margin: 0 auto 1.5rem; }
.bk-progress span { flex: 1; height: 3px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 999px; }
.bk-progress span.done { background: var(--accent); border-color: var(--accent); }

.bk-screen {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1.75rem;
}
.bk-screen .kicker { font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.bk-screen h2 { font-family: var(--font-display); font-size: var(--fs-h1); letter-spacing: -0.02em; font-weight: 400; margin-top: 0.5rem; }
.bk-screen .sub { color: var(--text-muted); margin-top: 0.5rem; }

.bk-options { margin-top: 1.25rem; display: grid; gap: 0.625rem; }
.bk-option {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.125rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  cursor: pointer; text-align: left; width: 100%; font: inherit; color: inherit;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.bk-option:hover { border-color: var(--text-muted); }
.bk-option.selected { border-color: var(--accent); background: color-mix(in oklab, var(--accent) 6%, var(--surface)); }
.bk-option .title { font-weight: 500; }
.bk-option .meta { color: var(--text-muted); font-size: var(--fs-body-sm); margin-top: 0.1rem; }
.bk-option .right { text-align: right; }
.bk-option .right .price { font-family: var(--font-mono); }
.bk-option .right .duration { font-family: var(--font-mono); color: var(--text-muted); font-size: var(--fs-caption); }

.bk-staff { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 0.625rem; }
.bk-staff .bk-option { gap: 0.875rem; }
.bk-avatar {
  width: 2.75rem; height: 2.75rem; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 600; font-size: var(--fs-body-sm);
}

.bk-days { display: flex; gap: 0.5rem; overflow-x: auto; padding-bottom: 0.5rem; margin-top: 1rem; }
.bk-day {
  flex: 0 0 auto; padding: 0.75rem 1rem; text-align: center;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--surface); cursor: pointer; font: inherit; color: inherit;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.bk-day:hover { border-color: var(--text-muted); }
.bk-day.selected { border-color: var(--accent); background: color-mix(in oklab, var(--accent) 6%, var(--surface)); }
.bk-day .l { font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.bk-day .d { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: 400; margin-top: 0.25rem; }

.bk-slots { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.5rem; margin-top: 1rem; }
.bk-slot {
  padding: 0.75rem 0; text-align: center;
  border: 1px solid var(--border); border-radius: var(--radius);
  font-family: var(--font-mono); font-size: var(--fs-body-sm);
  background: var(--surface); cursor: pointer; color: var(--text);
  transition: border-color var(--t-fast), background var(--t-fast), color var(--t-fast);
}
.bk-slot:hover { border-color: var(--accent); }
.bk-slot.selected { background: var(--accent); color: var(--accent-fg); border-color: var(--accent); }
.bk-slot.taken { color: var(--text-muted); text-decoration: line-through; opacity: 0.5; cursor: not-allowed; }

.bk-summary {
  margin-top: 1.25rem; padding: 1rem; border: 1px solid var(--border); border-radius: var(--radius);
}
.bk-summary .kicker { font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.bk-summary dl { display: grid; grid-template-columns: auto 1fr; gap: 0.5rem 1rem; margin-top: 0.75rem; font-size: var(--fs-body-sm); }
.bk-summary dt { color: var(--text-muted); }
.bk-summary dd { text-align: right; }
.bk-summary dd.mono { font-family: var(--font-mono); }

.bk-field { display: flex; flex-direction: column; gap: 0.375rem; margin-top: 1rem; }
.bk-field label { font-size: var(--fs-body-sm); font-weight: 500; }
.bk-field input {
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--surface); color: var(--text); font: inherit;
  transition: border-color var(--t-fast);
}
.bk-field input:focus { outline: none; border-color: var(--accent); }
.bk-field .hint { font-size: var(--fs-caption); color: var(--text-muted); }

.bk-footnav { display: flex; justify-content: space-between; gap: 0.75rem; margin-top: 1.5rem; }
.bk-footnav .spacer { flex: 1; }

.bk-confirm { text-align: center; padding: 2rem 0; }
.bk-confirm .check {
  width: 64px; height: 64px; margin: 0 auto;
  display: flex; align-items: center; justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--accent);
  background: color-mix(in oklab, var(--accent) 14%, var(--surface));
  color: var(--accent);
}
.bk-confirm h1 { font-family: var(--font-display); font-size: var(--fs-display-lg); font-weight: 400; letter-spacing: -0.02em; margin-top: 1.5rem; }
.bk-confirm p.big { color: var(--text-muted); font-size: var(--fs-body-lg); margin-top: 0.5rem; }
.bk-confirm .card { max-width: 28rem; margin: 1.75rem auto 0; padding: 1.5rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); text-align: left; }
.bk-confirm .actions { margin-top: 1.5rem; display: flex; gap: 0.75rem; justify-content: center; }

/* ---------- Dashboard ---------- */
.bk-dash { display: grid; grid-template-columns: 240px 1fr; min-height: calc(100vh - 4rem); background: var(--bg); }

.bk-side {
  background: var(--surface); border-right: 1px solid var(--border);
  padding: 1rem 0.75rem;
  position: sticky; top: 4rem; align-self: start; height: calc(100vh - 4rem);
  display: flex; flex-direction: column; gap: 0.5rem;
}
.bk-side .tenant {
  display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius);
  font-size: var(--fs-body-sm);
}
.bk-side .tenant .logo {
  width: 22px; height: 22px; border-radius: 4px; background: var(--accent); color: var(--accent-fg);
  display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 600;
}
.bk-side nav { flex: 1; margin-top: 0.5rem; display: flex; flex-direction: column; gap: 2px; }
.bk-side nav a {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.5rem 0.75rem; border-radius: var(--radius);
  color: var(--text-muted); font-size: var(--fs-body-sm);
  transition: background var(--t-fast), color var(--t-fast);
}
.bk-side nav a:hover { background: var(--surface-2); color: var(--text); }
.bk-side nav a.active { background: var(--surface-2); color: var(--text); font-weight: 500; }
.bk-side nav a svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.3; }
.bk-side .note { margin-top: 0.75rem; padding: 0.75rem; font-size: var(--fs-caption); color: var(--text-muted); border-top: 1px solid var(--border); }
.bk-side .user { padding: 0.5rem 0.75rem; border-top: 1px solid var(--border); display: flex; align-items: center; gap: 0.75rem; margin-top: auto; }
.bk-side .user .avatar { width: 30px; height: 30px; border-radius: 999px; background: var(--accent); color: var(--accent-fg); display: flex; align-items: center; justify-content: center; font-size: var(--fs-body-sm); font-weight: 600; }
.bk-side .user .meta { display: flex; flex-direction: column; }
.bk-side .user .meta .n { font-size: var(--fs-body-sm); font-weight: 500; }
.bk-side .user .meta .r { font-size: var(--fs-caption); color: var(--text-muted); }
.bk-side .switch { padding: 0.5rem 0.75rem; border-top: 1px solid var(--border); font-size: var(--fs-caption); color: var(--text-muted); }
.bk-side .switch a:hover { color: var(--text); }

.bk-main { min-width: 0; }
.bk-main header.page {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem;
  padding: 1.5rem 2rem; border-bottom: 1px solid var(--border);
}
.bk-main header.page h1 { font-family: var(--font-display); font-size: var(--fs-h1); font-weight: 400; letter-spacing: -0.02em; }
.bk-main header.page .sub { color: var(--text-muted); font-size: var(--fs-body-sm); margin-top: 0.25rem; }
.bk-main header.page .actions { display: flex; gap: 0.5rem; }
.bk-main .page-body { padding: 2rem; }

.bk-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1rem; margin-bottom: 2rem; }
.bk-kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.25rem; }
.bk-kpi .label { font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.bk-kpi .value { font-family: var(--font-display); font-size: 1.75rem; font-weight: 400; letter-spacing: -0.02em; margin-top: 0.5rem; line-height: 1.05; }
.bk-kpi .value.mono { font-family: var(--font-mono); letter-spacing: 0; }
.bk-kpi .hint { color: var(--text-muted); font-size: var(--fs-body-sm); margin-top: 0.25rem; }

.bk-panels { display: grid; grid-template-columns: 2fr 1fr; gap: 1.25rem; }
.bk-panel { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); }
.bk-panel > header { padding: 1rem 1.25rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
.bk-panel > header h2 { font-family: var(--font-display); font-size: var(--fs-h2); letter-spacing: -0.02em; font-weight: 400; }
.bk-panel > .inner { padding: 0.75rem; }
.bk-panel.dashed { border-style: dashed; }

.bk-appt {
  display: flex; align-items: stretch; gap: 0.75rem;
  padding: 0.75rem; border-radius: var(--radius);
  cursor: pointer;
}
.bk-appt:hover { background: var(--surface-2); }
.bk-appt .time { width: 3.5rem; text-align: right; font-family: var(--font-mono); font-size: var(--fs-body-sm); flex-shrink: 0; }
.bk-appt .time .len { display: block; font-size: var(--fs-caption); color: var(--text-muted); }
.bk-appt .stripe { width: 3px; border-radius: 999px; background: var(--accent); flex-shrink: 0; }
.bk-appt .info { flex: 1; min-width: 0; }
.bk-appt .info .who { font-weight: 500; display: flex; align-items: center; gap: 0.5rem; }
.bk-appt .info .what { color: var(--text-muted); font-size: var(--fs-body-sm); }
.bk-appt .info .note { color: var(--text-muted); font-size: var(--fs-body-sm); font-style: italic; margin-top: 0.25rem; }
.bk-appt .actions { display: flex; gap: 0.5rem; opacity: 0; transition: opacity var(--t-fast); }
.bk-appt:hover .actions { opacity: 1; }

.bk-badge {
  display: inline-flex; align-items: center; padding: 0.1rem 0.45rem;
  font-size: 10px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
  background: color-mix(in oklab, var(--accent) 12%, var(--surface));
  color: var(--accent);
  border: 1px solid color-mix(in oklab, var(--accent) 25%, transparent);
  border-radius: 4px;
}
.bk-badge.success { background: color-mix(in oklab, var(--success) 12%, var(--surface)); color: var(--success); border-color: color-mix(in oklab, var(--success) 25%, transparent); }
.bk-badge.warning { background: color-mix(in oklab, var(--warm) 12%, var(--surface)); color: var(--warm); border-color: color-mix(in oklab, var(--warm) 25%, transparent); }

.bk-side-list { display: flex; flex-direction: column; gap: 0.75rem; padding: 1.25rem; }
.bk-side-list .row { display: flex; align-items: center; gap: 0.75rem; font-size: var(--fs-body-sm); }
.bk-side-list .row .avatar { width: 30px; height: 30px; border-radius: 999px; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 600; }
.bk-side-list .row .meta { display: flex; flex-direction: column; }
.bk-side-list .row .meta .n { font-weight: 500; }
.bk-side-list .row .meta .s { color: var(--text-muted); font-size: var(--fs-caption); }

.bk-table { width: 100%; }
.bk-table th, .bk-table td { text-align: left; padding: 0.875rem 1rem; border-bottom: 1px solid var(--border); }
.bk-table th { font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); font-weight: 500; background: var(--surface-2); }
.bk-table tbody tr:hover { background: var(--surface-2); }
.bk-table .mono { font-family: var(--font-mono); font-size: var(--fs-body-sm); }
.bk-table td.right, .bk-table th.right { text-align: right; }

/* Calendar grid */
.bk-cal { border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--surface); }
.bk-cal .head { display: grid; grid-template-columns: 64px repeat(7, 1fr); background: var(--surface-2); border-bottom: 1px solid var(--border); }
.bk-cal .head .cell { padding: 0.75rem; border-left: 1px solid var(--border); }
.bk-cal .head .cell:first-child { border-left: none; }
.bk-cal .head .cell .day { font-size: var(--fs-caption); letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-muted); }
.bk-cal .head .cell .date { font-family: var(--font-display); font-size: var(--fs-h3); font-weight: 400; margin-top: 0.25rem; }
.bk-cal .head .cell.active { background: var(--surface); }
.bk-cal .head .cell.active .date { color: var(--accent); }
.bk-cal .grid { display: grid; grid-template-columns: 64px repeat(7, 1fr); position: relative; }
.bk-cal .hours { display: flex; flex-direction: column; }
.bk-cal .hours .hour { height: 56px; border-bottom: 1px solid var(--border); padding: 4px 8px 0 0; text-align: right; font-family: var(--font-mono); font-size: 11px; color: var(--text-muted); }
.bk-cal .col { position: relative; border-left: 1px solid var(--border); }
.bk-cal .col .slot { height: 56px; border-bottom: 1px solid var(--border); }
.bk-cal .block {
  position: absolute; left: 4px; right: 4px;
  border: 1px solid color-mix(in oklab, var(--accent) 35%, transparent);
  background: color-mix(in oklab, var(--accent) 14%, var(--surface));
  border-radius: 4px;
  padding: 4px 6px;
  overflow: hidden;
  cursor: pointer;
}
.bk-cal .block .t { font-size: 11px; font-weight: 500; color: var(--accent); }
.bk-cal .block .s { font-size: 10px; color: var(--text-muted); }

@media (max-width: 960px) {
  .bk-dash { grid-template-columns: 1fr; }
  .bk-side { position: static; height: auto; flex-direction: row; flex-wrap: wrap; border-right: none; border-bottom: 1px solid var(--border); }
  .bk-side nav { flex-direction: row; flex-wrap: wrap; margin-top: 0; }
  .bk-side .user, .bk-side .switch, .bk-side .note { width: 100%; }
  .bk-panels { grid-template-columns: 1fr; }
}
