/* ─────────────────────────────────────────────────────────────
   Booking widget — full-pane shadcn business calendar
   ───────────────────────────────────────────────────────────── */

.booking {
  position: relative;
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: var(--radius);
  overflow: hidden;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

/* ── Header ──────────────────────────────────────────── */
.booking-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  flex-shrink: 0;
}
.booking-head .title {
  display: flex; align-items: center; gap: 0.6rem;
  font-size: 0.825rem; font-weight: 500;
}
.booking-head .title .icon {
  width: 24px; height: 24px;
  display: grid; place-items: center;
  border-radius: calc(var(--radius) - 2px);
  background: hsl(var(--primary) / 0.12);
  color: hsl(var(--primary));
  border: 1px solid hsl(var(--primary) / 0.3);
  font-size: 0.75rem;
}
.booking-head .right {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
}

/* ── Stepper ─────────────────────────────────────────── */
.booking-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  padding: 0.6rem 1.25rem;
  border-bottom: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  gap: 0.5rem;
  flex-shrink: 0;
}
.booking-steps .s {
  position: relative;
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: hsl(var(--muted-foreground));
  padding: 0.25rem 0;
  font-weight: 500;
}
.booking-steps .s .n {
  width: 18px; height: 18px;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  font-size: 0.65rem;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  flex-shrink: 0;
}
.booking-steps .s.is-done .n {
  background: hsl(var(--primary));
  border-color: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
}
.booking-steps .s.is-done .n::before { content: "✓"; font-size: 0.65rem; }
.booking-steps .s.is-done .n span { display: none; }
.booking-steps .s.is-current { color: hsl(var(--foreground)); }
.booking-steps .s.is-current .n {
  background: hsl(var(--primary) / 0.12);
  border-color: hsl(var(--primary));
  color: hsl(var(--primary));
}

/* ── Body ────────────────────────────────────────────── */
.booking-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-height: 0;
}
.booking-body::-webkit-scrollbar { width: 8px; }
.booking-body::-webkit-scrollbar-track { background: transparent; }
.booking-body::-webkit-scrollbar-thumb { background: hsl(var(--border)); border-radius: 4px; }
.booking-body::-webkit-scrollbar-thumb:hover { background: hsl(var(--muted-foreground) / 0.4); }

.booking-body h3 {
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.booking-body .sub {
  font-size: 0.8rem;
  color: hsl(var(--muted-foreground));
  margin-top: -0.5rem;
}

/* ── Service list (full-width rows, not cramped grid) ── */
.svc-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.4rem;
}
.svc {
  text-align: left;
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: 0.85rem;
  align-items: center;
  padding: 0.75rem 0.85rem;
  background: hsl(var(--card));
  border: 1px solid hsl(var(--border));
  border-radius: calc(var(--radius) - 2px);
  cursor: pointer;
  transition: border-color 160ms, background 160ms;
}
.svc:hover { border-color: hsl(var(--primary) / 0.5); background: hsl(var(--accent)); }
.svc.is-selected {
  border-color: hsl(var(--primary));
  background: hsl(var(--primary) / 0.06);
}
.svc-icon {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border-radius: calc(var(--radius) - 2px);
  background: hsl(var(--secondary));
  color: hsl(var(--primary));
  font-size: 0.85rem;
  border: 1px solid hsl(var(--border));
}
.svc.is-selected .svc-icon {
  background: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
  border-color: hsl(var(--primary));
}
.svc .info { min-width: 0; }
.svc .name { font-size: 0.875rem; font-weight: 500; line-height: 1.2; }
.svc .meta { font-size: 0.72rem; color: hsl(var(--muted-foreground)); margin-top: 0.1rem; display: flex; gap: 0.4rem; align-items: center; }
.svc .meta .dot { width: 3px; height: 3px; border-radius: 50%; background: hsl(var(--muted-foreground) / 0.5); }
.svc .price {
  font-variant-numeric: tabular-nums;
  font-size: 0.85rem;
  color: hsl(var(--foreground));
  font-weight: 500;
  text-align: right;
  line-height: 1.1;
  white-space: nowrap;
}
.svc.is-selected .price { color: hsl(var(--primary)); }

/* ── Calendar ────────────────────────────────────────── */
.cal { display: grid; gap: 0.6rem; }
.cal-head {
  display: flex; align-items: center; justify-content: space-between;
}
.cal-head .month {
  font-size: 0.95rem;
  font-weight: 600;
  color: hsl(var(--foreground));
  text-transform: capitalize;
  letter-spacing: -0.01em;
}
.cal-nav { display: flex; gap: 0.3rem; }
.cal-nav button {
  width: 30px; height: 30px;
  display: grid; place-items: center;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  color: hsl(var(--foreground));
  transition: background 150ms;
  font-size: 0.9rem;
}
.cal-nav button:hover:not(:disabled) { background: hsl(var(--accent)); }
.cal-nav button:disabled { opacity: 0.4; cursor: not-allowed; }

.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
}
.cal-dow {
  font-size: 0.65rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: hsl(var(--muted-foreground));
  text-align: center;
  padding: 0.25rem 0;
  font-weight: 500;
}
.cal-day {
  position: relative;
  aspect-ratio: 1;
  display: grid; place-items: center;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid transparent;
  background: transparent;
  font-size: 0.825rem;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: hsl(var(--foreground));
  cursor: pointer;
  transition: background 130ms, border-color 130ms, color 130ms;
}
.cal-day:hover:not(:disabled) { background: hsl(var(--accent)); }
.cal-day:disabled, .cal-day.is-other { color: hsl(var(--muted-foreground) / 0.35); cursor: not-allowed; background: transparent; }
.cal-day.is-today { border-color: hsl(var(--primary) / 0.5); }
.cal-day.is-selected {
  background: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
  border-color: hsl(var(--primary));
}
.cal-day.is-closed { color: hsl(var(--muted-foreground) / 0.3); }
.cal-day.is-closed::after {
  content: ""; position: absolute; bottom: 5px; left: 50%; transform: translateX(-50%);
  width: 12px; height: 1px; background: hsl(var(--muted-foreground) / 0.3);
}

/* ── Time slots ──────────────────────────────────────── */
.slots-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(76px, 1fr));
  gap: 0.4rem;
}
.slot {
  height: 36px;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  color: hsl(var(--foreground));
  font-size: 0.825rem;
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  cursor: pointer;
  transition: background 150ms, border-color 150ms, color 150ms;
}
.slot:hover:not(:disabled) { background: hsl(var(--accent)); border-color: hsl(var(--primary) / 0.5); }
.slot.is-selected {
  background: hsl(var(--primary));
  color: hsl(var(--primary-foreground));
  border-color: hsl(var(--primary));
}
.slot:disabled {
  text-decoration: line-through;
  text-decoration-color: hsl(var(--muted-foreground) / 0.4);
  color: hsl(var(--muted-foreground) / 0.45);
  cursor: not-allowed;
  background: transparent;
}
.slots-empty {
  grid-column: 1 / -1;
  padding: 1.25rem;
  text-align: center;
  color: hsl(var(--muted-foreground));
  font-size: 0.8125rem;
  border: 1px dashed hsl(var(--border));
  border-radius: var(--radius);
}

/* ── Form fields ─────────────────────────────────────── */
.fields { display: grid; gap: 0.75rem; }
.fields label {
  display: grid; gap: 0.3rem;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  font-weight: 500;
  color: hsl(var(--foreground) / 0.85);
}
.fields input, .fields textarea {
  width: 100%;
  padding: 0.55rem 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(var(--input));
  background: hsl(var(--card));
  color: hsl(var(--foreground));
  font-family: var(--ff-sans);
  font-size: 0.875rem;
  transition: border-color 150ms, box-shadow 150ms;
}
.fields input::placeholder, .fields textarea::placeholder { color: hsl(var(--muted-foreground) / 0.6); }
.fields input:focus, .fields textarea:focus {
  outline: none;
  border-color: hsl(var(--primary));
  box-shadow: 0 0 0 3px hsl(var(--primary) / 0.18);
}
.fields textarea { resize: vertical; min-height: 64px; font-family: var(--ff-sans); }

/* ── Summary line ────────────────────────────────────── */
.summary {
  display: grid; gap: 0.25rem;
  padding: 0.75rem 0.9rem;
  background: hsl(var(--muted) / 0.7);
  border: 1px solid hsl(var(--border));
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.8125rem;
}
.summary .row { display: flex; justify-content: space-between; gap: 1rem; }
.summary .row .l { color: hsl(var(--muted-foreground)); }
.summary .row .v { color: hsl(var(--foreground)); font-variant-numeric: tabular-nums; font-weight: 500; }

/* ── Footer with nav ─────────────────────────────────── */
.booking-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.75rem 1.25rem;
  border-top: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  flex-shrink: 0;
}
.booking-foot .hint {
  font-size: 0.75rem;
  color: hsl(var(--muted-foreground));
  display: flex;
  align-items: center;
  gap: 0.4rem;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.booking-foot .nav-btns { display: flex; gap: 0.4rem; }

/* ── Confirmation ────────────────────────────────────── */
.confirm {
  text-align: center;
  display: grid; gap: 0.5rem;
  padding: 1rem 0;
  justify-items: center;
}
.confirm .check {
  width: 48px; height: 48px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: hsl(var(--success) / 0.14);
  border: 1px solid hsl(var(--success) / 0.5);
  color: hsl(var(--success));
  font-size: 1.2rem;
}
.confirm h3 { font-size: 1.25rem; font-weight: 600; }
.confirm p { color: hsl(var(--muted-foreground)); font-size: 0.875rem; max-width: 40ch; }
.confirm .recap {
  margin-top: 0.75rem;
  width: 100%; max-width: 360px;
  padding: 0;
  border-radius: var(--radius);
  border: 1px solid hsl(var(--border));
  background: hsl(var(--muted) / 0.5);
  overflow: hidden;
  font-size: 0.85rem;
  text-align: left;
}
.confirm .recap .row {
  display: flex; justify-content: space-between; gap: 1rem;
  padding: 0.6rem 0.9rem;
  border-bottom: 1px solid hsl(var(--border));
}
.confirm .recap .row:last-child { border-bottom: none; }
.confirm .recap .l { color: hsl(var(--muted-foreground)); font-size: 0.75rem; letter-spacing: 0.04em; }
.confirm .recap .v { font-variant-numeric: tabular-nums; font-weight: 500; }
.confirm .id {
  margin-top: 0.5rem;
  font-family: var(--ff-mono);
  font-size: 0.7rem;
  color: hsl(var(--muted-foreground));
}

/* ── Skeleton ────────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, hsl(var(--secondary)) 0%, hsl(var(--muted)) 50%, hsl(var(--secondary)) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
  border-radius: calc(var(--radius) - 2px);
}
@keyframes shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* ── Error inline ────────────────────────────────────── */
.inline-error {
  font-size: 0.8125rem;
  color: hsl(var(--destructive));
  padding: 0.6rem 0.85rem;
  background: hsl(var(--destructive) / 0.08);
  border: 1px solid hsl(var(--destructive) / 0.3);
  border-radius: calc(var(--radius) - 2px);
}
