/* ==========================================================================
   Contractor 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.
   ========================================================================== */

/* Service-request 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; }

/* Estimate-request photo thumbnails (Service Requests page) */
.order-photo-row {
  display: flex;
  gap: 8px;
  margin: 8px 0;
  flex-wrap: wrap;
}
.order-photo-thumb {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
}

/* ==========================================================================
   Service badges (Services & Categories page)
   ========================================================================== */
.emergency-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(220, 38, 38, 0.1);
  color: #dc2626;
}
.featured-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(249, 115, 22, 0.12);
  color: #c2410c;
}

/* ==========================================================================
   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 + Reviews 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;
}

/* Read-only star display on review cards */
.review-admin-stars {
  color: #f59e0b;
  font-size: 13px;
  letter-spacing: 1px;
}
.review-admin-stars .star-empty {
  color: var(--color-border);
}

/* ==========================================================================
   Project grid (dashboard-side thumbnails)
   ========================================================================== */
.project-thumb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 16px;
}
.project-thumb-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
}
.project-thumb,
.project-thumb-placeholder {
  width: 100%;
  height: 140px;
  display: block;
}
.project-thumb {
  object-fit: cover;
  background: var(--color-bg-alt);
}
.project-thumb-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  color: var(--color-text-muted);
  background: var(--color-bg-alt);
}
.project-thumb-before-after {
  display: flex;
  width: 100%;
  height: 140px;
  position: relative;
}
.project-thumb-before-after img {
  width: 50%;
  height: 100%;
  object-fit: cover;
}
.project-thumb-img-wrap {
  position: relative;
}
.project-thumb-video {
  position: absolute;
  right: 8px;
  bottom: 8px;
  font-size: 16px;
}
.project-thumb-body {
  padding: 10px 12px;
}
.project-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;
}
.project-thumb-title {
  font-size: 13px;
  font-weight: 700;
  margin: 0 0 4px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.project-thumb-caption {
  font-size: 13px;
  color: var(--color-text-muted);
  margin: 0 0 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.project-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;
}

/* ==========================================================================
   Review admin cards (Reviews page)
   ========================================================================== */
.review-admin-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.review-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;
}
.review-admin-avatar {
  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);
}
.review-admin-body { flex: 1; min-width: 0; }
.review-admin-header {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 2px;
}
.review-admin-name { font-weight: 700; margin: 0; }
.review-admin-project-type {
  font-size: 11px;
  font-weight: 700;
  color: var(--color-text-muted);
  background: var(--color-bg-alt);
  padding: 2px 8px;
  border-radius: 999px;
}
.review-admin-comment {
  font-size: 13px;
  color: var(--color-text-muted);
  margin: 4px 0 0;
}
.review-admin-actions {
  display: flex;
  gap: 12px;
  flex-shrink: 0;
}

/* ==========================================================================
   Before & After multi-photo uploader
   ========================================================================== */
.ba-section {
  margin-bottom: 20px;
}
.ba-section-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.ba-section-label {
  font-size: 13px;
  font-weight: 700;
  flex: 1;
}
.ba-count {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-left: 4px;
}
.ba-photo-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  min-height: 72px;
}
.ba-photo-slot {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
}
.ba-photo-slot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ba-photo-remove {
  position: absolute;
  top: 3px;
  right: 3px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(0,0,0,.55);
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.ba-photo-remove:hover { background: #dc2626; }
.ba-photo-add-slot {
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  border: 2px dashed var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: border-color .15s, color .15s;
}
.ba-photo-add-slot:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* "+N more" badge on project thumbnail card */
.ba-more-badge {
  position: absolute;
  bottom: 6px;
  right: 6px;
  background: rgba(0,0,0,.6);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 999px;
}

/* ==========================================================================
   Reviews page additions
   ========================================================================== */
.reviews-info-msg {
  font-size: 13px;
  color: var(--color-text-muted);
  margin-bottom: 16px;
}
.tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: #dc2626;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  border-radius: 999px;
  margin-left: 6px;
  vertical-align: middle;
}
.tab-badge.approved {
  background: #16a34a;
}
.review-admin-date {
  font-size: 11px;
  color: var(--color-text-muted);
  margin-left: auto;
  white-space: nowrap;
}
.review-approved-badge {
  font-size: 12px;
  font-weight: 700;
  color: #16a34a;
}
.btn-report {
  background: none;
  border: 1.5px solid #f97316;
  color: #f97316;
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, color .15s;
}
.btn-report:hover { background: #f97316; color: #fff; }
.btn-report:disabled { opacity: .5; cursor: default; }
.review-reported-badge {
  font-size: 12px;
  font-weight: 700;
  color: #dc2626;
}

/* ==========================================================================
   Multi-category selector
   ========================================================================== */
.cat-tags-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
  min-height: 0;
}
.cat-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--color-accent);
  color: #fff;
  border-radius: 999px;
  padding: 4px 10px 4px 12px;
  font-size: 12px;
  font-weight: 700;
}
.cat-tag-remove {
  border: none;
  background: none;
  color: rgba(255,255,255,.8);
  cursor: pointer;
  font-size: 13px;
  line-height: 1;
  padding: 0;
}
.cat-tag-remove:hover { color: #fff; }

.cat-chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 10px;
}
.cat-chip {
  border: 1px solid var(--color-border);
  background: #fff;
  border-radius: 999px;
  padding: 5px 13px;
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-muted);
  cursor: pointer;
  font-family: inherit;
  transition: border-color .15s, background .15s, color .15s;
}
.cat-chip:hover { border-color: var(--color-accent); color: var(--color-accent); }
.cat-chip.active {
  border-color: var(--color-accent);
  background: var(--color-accent-soft);
  color: var(--color-accent-2);
}

.cat-custom-row {
  display: flex;
  gap: 8px;
  align-items: center;
}
.cat-custom-input {
  flex: 1;
  padding: 8px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-family: inherit;
}

/* ==========================================================================
   Opening hours — new dropdown grid
   ========================================================================== */
.hours-grid-new {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.hours-row-new {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.hours-day-label {
  width: 90px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text);
  flex-shrink: 0;
}
.hours-times-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  transition: opacity 0.2s;
}
.hours-times-wrap select {
  flex: 1;
  min-width: 110px;
  padding: 8px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-family: inherit;
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
}
.hours-sep {
  font-size: 13px;
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.hours-closed-label {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  color: var(--color-text-muted);
  cursor: pointer;
  white-space: nowrap;
}
.hours-closed-label input[type="checkbox"] {
  width: 15px;
  height: 15px;
  accent-color: var(--color-accent);
}

/* ==========================================================================
   Services quick-add (create form)
   ========================================================================== */
.svc-list {
  margin-bottom: 10px;
}
.svc-empty {
  font-size: 13px;
  color: var(--color-text-muted);
  margin: 0 0 8px;
}
.svc-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 12px;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  margin-bottom: 6px;
}
.svc-item-name {
  font-size: 13px;
  font-weight: 600;
}
.svc-remove {
  color: var(--color-text-muted);
  font-size: 16px;
  line-height: 1;
  flex-shrink: 0;
}
.svc-remove:hover { color: #dc2626; }
.svc-add-row {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.svc-input-name {
  flex: 2;
  min-width: 160px;
  padding: 9px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-family: inherit;
}
.svc-input-price {
  flex: 1;
  min-width: 90px;
  max-width: 130px;
  padding: 9px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-family: inherit;
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 640px) {
  .qr-preset-grid { grid-template-columns: repeat(2, 1fr); }
  .hours-row-new { gap: 8px; }
  .hours-day-label { width: 75px; font-size: 12px; }
  .hours-times-wrap select { min-width: 90px; font-size: 12px; padding: 7px 8px; }
  .svc-add-row { flex-direction: column; align-items: stretch; }
  .svc-input-name, .svc-input-price { max-width: 100%; }
}
