/* ==========================================================================
   Beauty Profile dashboard
   Loaded after /style.css, /dashboard/dashboard.css and
   /dashboard/restaurant/restaurant.css (reused for generic dashboard
   styles: .rest-form-grid, .upload-field, .hours-grid, .rest-header-card,
   .rest-link-row, .rest-qr-card, .tabs, .item-cell,
   .badge-available/.badge-unavailable, .toggle-row, .upgrade-banner,
   .order-list/.order-card/etc.) - small additions only.
   ========================================================================== */

/* Booking status badge not covered by restaurant.css (which only defines
   .order-status-new / .order-status-served / .order-status-cancelled) */
.order-status-confirmed { background: rgba(34, 197, 94, 0.12); color: #15803d; }

/* ==========================================================================
   Preset category chips ("+ Add Category" modal)
   ========================================================================== */
.preset-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}
.preset-chip {
  border: 1px solid var(--color-border);
  background: #fff;
  border-radius: 999px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-muted);
  cursor: pointer;
  font-family: inherit;
}
.preset-chip:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.preset-chip.active {
  border-color: var(--color-accent);
  background: var(--color-accent-soft);
  color: var(--color-accent-2);
}

/* ==========================================================================
   Star-rating picker (Overview rating editor + Branding testimonial modal)
   ========================================================================== */
.star-rating-input {
  display: inline-flex;
  gap: 2px;
}
.star-rating-input .star-btn {
  border: none;
  background: none;
  font-size: 20px;
  line-height: 1;
  padding: 0;
  cursor: pointer;
  color: var(--color-border);
}
.star-rating-input .star-btn.active {
  color: #f59e0b;
}

/* ==========================================================================
   Portfolio grid (dashboard-side thumbnails)
   ========================================================================== */
.portfolio-thumb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 16px;
}
.portfolio-thumb-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.portfolio-thumb,
.portfolio-thumb-placeholder {
  width: 100%;
  height: 140px;
  display: block;
}
.portfolio-thumb {
  object-fit: cover;
  background: var(--color-bg-alt);
}
.portfolio-thumb-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  color: var(--color-text-muted);
  background: var(--color-bg-alt);
}
.portfolio-thumb-before-after {
  display: flex;
  width: 100%;
  height: 140px;
}
.portfolio-thumb-before-after img {
  width: 50%;
  height: 100%;
  object-fit: cover;
}
.portfolio-thumb-body {
  padding: 10px 12px;
}
.portfolio-thumb-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--color-bg-alt);
  color: var(--color-text-muted);
  margin-bottom: 6px;
}
.portfolio-thumb-caption {
  font-size: 13px;
  color: var(--color-text-muted);
  margin: 0 0 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.portfolio-thumb-actions {
  display: flex;
  gap: 12px;
}

/* ==========================================================================
   QR style presets (Branding page)
   ========================================================================== */
.qr-preset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 16px;
  margin-bottom: 8px;
}
.qr-preset-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 16px;
  text-align: center;
  cursor: pointer;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.qr-preset-card:hover { border-color: var(--color-accent); }
.qr-preset-card.active {
  border-color: var(--color-accent);
  box-shadow: var(--shadow-hover);
}
.qr-preset-card canvas {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  max-width: 100%;
}
.qr-preset-name {
  font-size: 13px;
  font-weight: 700;
}

/* ==========================================================================
   Testimonial admin cards (Branding page)
   ========================================================================== */
.testimonial-admin-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.testimonial-admin-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 14px 16px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.testimonial-admin-photo {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--color-bg-alt);
  flex-shrink: 0;
}
.testimonial-admin-photo-placeholder {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  color: #fff;
  background: var(--color-accent);
}
.testimonial-admin-body { flex: 1; min-width: 0; }
.testimonial-admin-name { font-weight: 700; margin: 0 0 2px; }
.testimonial-admin-comment {
  font-size: 13px;
  color: var(--color-text-muted);
  margin: 4px 0 0;
}
.testimonial-admin-actions {
  display: flex;
  gap: 12px;
  flex-shrink: 0;
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 640px) {
  .qr-preset-grid { grid-template-columns: repeat(2, 1fr); }
}
