/* ── Dispatch Jobs App — Isolated CSS ── */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@500;700;800&family=Inter:wght@300;400;500;600&display=swap');

/* ── Variables (scoped) ── */
#dj-app-root {
  --dja-bg:        #f0f4f8;
  --dja-surface:   #ffffff;
  --dja-surface2:  #f8fafc;
  --dja-border:    #e2e8f0;
  --dja-border2:   #cbd5e1;
  --dja-accent:    #2563eb;
  --dja-accent-lt: #eff6ff;
  --dja-accent-dk: #1d4ed8;
  --dja-text:      #0f172a;
  --dja-text2:     #475569;
  --dja-muted:     #94a3b8;
  --dja-success:   #16a34a;
  --dja-danger:    #dc2626;
  --dja-warning:   #d97706;
  --dja-nav-w:     240px;
  --dja-nav-bg:    #0f172a;
  --dja-nav-text:  #cbd5e1;
  --dja-radius:    10px;
  --dja-radius-sm: 6px;
  --dja-shadow:    0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.06);
  --dja-shadow-lg: 0 8px 32px rgba(0,0,0,.16);
  --dja-sans:      'Inter', system-ui, sans-serif;
  --dja-display:   'Syne', system-ui, sans-serif;
  --dja-mono:      'IBM Plex Mono', 'Courier New', monospace;
}

/* ── Hard reset inside app root ── */
#dj-app-root, #dj-app-root * { box-sizing: border-box !important; }
#dj-app-root { font-family: var(--dja-sans) !important; color: var(--dja-text) !important; font-size: 14px !important; line-height: 1.6 !important; }
#dj-app-root h1, #dj-app-root h2, #dj-app-root h3, #dj-app-root h4, #dj-app-root h5 { font-family: var(--dja-display) !important; margin: 0 !important; padding: 0 !important; border: none !important; }
#dj-app-root p { margin: 0 !important; }
#dj-app-root a { text-decoration: none !important; }
#dj-app-root button { font-family: var(--dja-sans) !important; cursor: pointer !important; }
#dj-app-root input, #dj-app-root select, #dj-app-root textarea { font-family: var(--dja-sans) !important; }
#dj-app-root ul, #dj-app-root ol { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.dj-app-hidden { display: none !important; }
#dj-app-root .dj-app-hidden { display: none !important; }
#dj-app-root .dj-app-modal-backdrop.dj-app-hidden { display: none !important; }

/* ── Login Screen ── */
#dj-app-root .dj-login-screen {
  min-height: 80vh; display: flex !important; align-items: center !important;
  justify-content: center !important; background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 100%);
  padding: 40px 20px; border-radius: var(--dja-radius);
}
#dj-app-root .dj-login-card {
  background: #fff; border-radius: 16px; padding: 44px 40px;
  width: 100%; max-width: 420px; box-shadow: 0 24px 64px rgba(0,0,0,.35);
}
#dj-app-root .dj-login-brand { text-align: center; margin-bottom: 32px; }
#dj-app-root .dj-login-logo {
  width: 60px; height: 60px; background: linear-gradient(135deg, #2563eb, #7c3aed);
  border-radius: 14px; display: flex !important; align-items: center !important;
  justify-content: center !important; margin: 0 auto 16px; color: #fff;
}
#dj-app-root .dj-login-brand h1 { font-size: 24px !important; font-weight: 800 !important; color: #0f172a !important; margin-bottom: 4px !important; }
#dj-app-root .dj-login-brand p { font-size: 14px !important; color: #475569 !important; }
#dj-app-root .dj-login-field { margin-bottom: 18px !important; }
#dj-app-root .dj-login-field label {
  display: flex !important; justify-content: space-between !important; align-items: center !important;
  font-size: 12px !important; font-weight: 600 !important; text-transform: uppercase !important;
  letter-spacing: .6px !important; color: #475569 !important; margin-bottom: 6px !important;
}
#dj-app-root .dj-login-forgot { font-size: 11px !important; text-transform: none !important; letter-spacing: 0 !important; color: #2563eb !important; font-weight: 400 !important; }
#dj-app-root .dj-login-pass-wrap { position: relative !important; }
#dj-app-root .dj-login-field input {
  width: 100% !important; padding: 11px 42px 11px 14px !important;
  border: 1.5px solid #e2e8f0 !important; border-radius: 6px !important;
  font-size: 14px !important; color: #0f172a !important; background: #fff !important;
  outline: none !important; transition: border-color .18s !important;
  box-shadow: none !important;
}
#dj-app-root .dj-login-field input:focus { border-color: #2563eb !important; box-shadow: 0 0 0 3px rgba(37,99,235,.12) !important; }
#dj-app-root .dj-pass-eye {
  position: absolute !important; right: 10px !important; top: 50% !important;
  transform: translateY(-50%) !important; background: none !important; border: none !important;
  color: #94a3b8 !important; padding: 4px !important; line-height: 1 !important;
}
#dj-app-root .dj-login-error {
  background: #fef2f2 !important; border: 1px solid #fecaca !important; color: #dc2626 !important;
  padding: 10px 14px !important; border-radius: 6px !important; font-size: 13px !important; margin-bottom: 14px !important;
}
#dj-app-root .dj-login-site { text-align: center !important; font-size: 12px !important; color: #94a3b8 !important; margin-top: 24px !important; }

/* ── App Shell — CRITICAL layout ── */
#dj-app-root .dj-app-shell {
  display: flex !important;
  flex-direction: row !important;
  min-height: 90vh !important;
  background: #f0f4f8 !important;
  position: relative !important;
  border-radius: var(--dja-radius) !important;
  overflow: hidden !important;
}

/* ── Sidebar Nav ── */
#dj-app-root .dj-app-nav {
  width: 220px !important;
  min-width: 220px !important;
  max-width: 220px !important;
  background: #0f172a !important;
  color: #cbd5e1 !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 20px 0 !important;
  height: auto !important;
  min-height: 90vh !important;
  flex-shrink: 0 !important;
  z-index: 10 !important;
}
#dj-app-root .dj-app-nav-brand {
  display: flex !important; align-items: center !important; gap: 10px !important;
  padding: 0 18px 20px !important; border-bottom: 1px solid rgba(255,255,255,.08) !important;
}
#dj-app-root .dj-app-nav-logo {
  width: 36px !important; height: 36px !important; min-width: 36px !important;
  background: linear-gradient(135deg, #2563eb, #7c3aed) !important;
  border-radius: 8px !important; display: flex !important; align-items: center !important;
  justify-content: center !important; color: #fff !important;
}
#dj-app-root .dj-app-nav-brand span {
  font-weight: 800 !important; font-size: 17px !important; color: #fff !important;
  white-space: nowrap !important;
}
#dj-app-root .dj-app-nav-tabs {
  flex: 1 !important; padding: 16px 10px !important;
  display: flex !important; flex-direction: column !important; gap: 2px !important;
}
#dj-app-root .dj-app-tab {
  display: flex !important; align-items: center !important; gap: 10px !important;
  padding: 10px 12px !important; border-radius: 6px !important;
  color: #cbd5e1 !important; font-size: 14px !important; font-weight: 500 !important;
  cursor: pointer !important; border: none !important; background: none !important;
  transition: all .15s !important; width: 100% !important; text-align: left !important;
}
#dj-app-root .dj-app-tab:hover { background: rgba(255,255,255,.07) !important; color: #fff !important; }
#dj-app-root .dj-app-tab.active { background: #2563eb !important; color: #fff !important; font-weight: 600 !important; }
#dj-app-root .dj-app-nav-user {
  display: flex !important; align-items: center !important; gap: 10px !important;
  padding: 16px 18px !important; border-top: 1px solid rgba(255,255,255,.08) !important;
}
#dj-app-root .dj-app-user-avatar {
  width: 34px !important; height: 34px !important; min-width: 34px !important;
  border-radius: 50% !important; background: linear-gradient(135deg, #2563eb, #7c3aed) !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-size: 13px !important; font-weight: 800 !important; color: #fff !important;
}
#dj-app-root .dj-app-user-info { display: flex !important; flex-direction: column !important; min-width: 0 !important; overflow: hidden !important; }
#dj-app-root .dj-app-user-name {
  font-size: 13px !important; font-weight: 600 !important; color: #fff !important;
  white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
  display: block !important;
}
#dj-app-root .dj-app-logout-btn {
  font-size: 11px !important; color: #94a3b8 !important; background: none !important;
  border: none !important; text-align: left !important; padding: 0 !important;
  transition: color .15s !important; display: block !important;
}
#dj-app-root .dj-app-logout-btn:hover { color: #f87171 !important; }

/* ── Content Area ── */
#dj-app-root .dj-app-content {
  flex: 1 !important; min-width: 0 !important; padding: 28px 28px !important;
  background: #f0f4f8 !important; overflow-y: auto !important;
}

/* ── Panels — CRITICAL: hide all, show only active ── */
#dj-app-root .dj-app-panel { display: none !important; }
#dj-app-root .dj-app-panel.active { display: block !important; }
#dj-app-root .dj-app-panel-header {
  display: flex !important; align-items: center !important; justify-content: space-between !important;
  margin-bottom: 22px !important; flex-wrap: wrap !important; gap: 12px !important;
}
#dj-app-root .dj-app-panel-header h2 { font-size: 22px !important; font-weight: 800 !important; color: #0f172a !important; }
#dj-app-root .dj-app-subtitle { font-size: 13px !important; color: #94a3b8 !important; margin-top: 2px !important; display: block !important; }

/* ── Stat Bar ── */
#dj-app-root .dj-app-stat-bar { display: flex !important; gap: 10px !important; flex-wrap: wrap !important; margin-bottom: 18px !important; }
#dj-app-root .dj-app-stat {
  flex: 1 !important; min-width: 90px !important; background: #fff !important;
  border: 1px solid #e2e8f0 !important; border-radius: 6px !important;
  padding: 12px 14px !important; cursor: pointer !important; transition: all .15s !important;
  border-left: 3px solid transparent !important;
}
#dj-app-root .dj-app-stat:hover, #dj-app-root .dj-app-stat.active { border-left-color: #2563eb !important; background: #eff6ff !important; }
#dj-app-root .dj-app-stat-num { font-size: 22px !important; font-weight: 800 !important; line-height: 1 !important; color: #0f172a !important; display: block !important; }
#dj-app-root .dj-app-stat-label { font-size: 10px !important; color: #94a3b8 !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .6px !important; margin-top: 4px !important; display: block !important; }

/* ── Filters ── */
#dj-app-root .dj-app-filters { margin-bottom: 18px !important; }
#dj-app-root .dj-app-search-wrap { position: relative !important; margin-bottom: 10px !important; }
#dj-app-root .dj-app-search-wrap svg { position: absolute !important; left: 12px !important; top: 50% !important; transform: translateY(-50%) !important; color: #94a3b8 !important; pointer-events: none !important; }
#dj-app-root .dj-app-search-wrap input {
  width: 100% !important; padding: 10px 14px 10px 38px !important;
  border: 1.5px solid #e2e8f0 !important; border-radius: 8px !important;
  font-size: 14px !important; color: #0f172a !important; background: #fff !important;
  outline: none !important; box-shadow: none !important;
}
#dj-app-root .dj-app-search-wrap input:focus { border-color: #2563eb !important; }
#dj-app-root .dj-app-pills { display: flex !important; gap: 6px !important; flex-wrap: wrap !important; }
#dj-app-root .dj-app-pill {
  padding: 5px 12px !important; border-radius: 20px !important;
  border: 1.5px solid #e2e8f0 !important; font-size: 12px !important; font-weight: 600 !important;
  cursor: pointer !important; background: #fff !important; color: #475569 !important; transition: all .15s !important;
}
#dj-app-root .dj-app-pill:hover { border-color: var(--pc, #2563eb) !important; color: var(--pc, #2563eb) !important; }
#dj-app-root .dj-app-pill.active { background: var(--pc, #2563eb) !important; border-color: var(--pc, #2563eb) !important; color: #fff !important; }

/* ── Table ── */
#dj-app-root .dj-app-table-wrap { background: #fff !important; border: 1px solid #e2e8f0 !important; border-radius: 10px !important; overflow: hidden !important; }
#dj-app-root .dj-app-table { width: 100% !important; border-collapse: collapse !important; font-size: 13px !important; }
#dj-app-root .dj-app-table thead th {
  background: #f8fafc !important; padding: 11px 16px !important; text-align: left !important;
  font-size: 11px !important; text-transform: uppercase !important; letter-spacing: .7px !important;
  color: #94a3b8 !important; font-weight: 700 !important;
  border-bottom: 1px solid #e2e8f0 !important; white-space: nowrap !important;
}
#dj-app-root .dj-app-table tbody tr {
  border-bottom: 1px solid #e2e8f0 !important; transition: background .1s !important; cursor: pointer !important;
}
#dj-app-root .dj-app-table tbody tr:last-child { border-bottom: none !important; }
#dj-app-root .dj-app-table tbody tr:hover { background: #f8fafc !important; }
#dj-app-root .dj-app-table td { padding: 12px 16px !important; vertical-align: middle !important; }
#dj-app-root .dj-app-job-num { font-family: var(--dja-mono) !important; font-size: 11px !important; color: #94a3b8 !important; }
#dj-app-root .dj-app-job-title { font-weight: 600 !important; color: #0f172a !important; }
#dj-app-root .dj-app-job-loc { font-size: 11px !important; color: #94a3b8 !important; margin-top: 2px !important; }
/* Badges */
#dj-app-root .dj-app-badge {
  display: inline-flex !important; align-items: center !important; padding: 3px 9px !important;
  border-radius: 20px !important; font-size: 11px !important; font-weight: 700 !important;
  letter-spacing: .4px !important; text-transform: uppercase !important; white-space: nowrap !important;
  background: color-mix(in srgb, var(--bc) 15%, transparent) !important;
  color: var(--bc) !important; border: 1px solid color-mix(in srgb, var(--bc) 28%, transparent) !important;
}
#dj-app-root .dj-app-priority { font-size: 12px !important; font-weight: 600 !important; }
#dj-app-root .dj-app-priority-low      { color: #94a3b8 !important; }
#dj-app-root .dj-app-priority-normal   { color: #475569 !important; }
#dj-app-root .dj-app-priority-high     { color: #d97706 !important; }
#dj-app-root .dj-app-priority-urgent   { color: #f97316 !important; }
#dj-app-root .dj-app-priority-critical { color: #dc2626 !important; font-weight: 800 !important; }
#dj-app-root .dj-app-avatar-sm {
  width: 26px !important; height: 26px !important; border-radius: 50% !important;
  background: linear-gradient(135deg, #2563eb, #7c3aed) !important;
  display: inline-flex !important; align-items: center !important; justify-content: center !important;
  font-size: 10px !important; font-weight: 800 !important; color: #fff !important; vertical-align: middle !important; margin-right: 5px !important;
}
#dj-app-root .dj-app-row-actions { display: flex !important; gap: 5px !important; opacity: 0 !important; transition: opacity .15s !important; }
#dj-app-root .dj-app-table tbody tr:hover .dj-app-row-actions { opacity: 1 !important; }
/* Pagination */
#dj-app-root .dj-app-pagination { display: flex !important; gap: 5px !important; justify-content: center !important; margin-top: 16px !important; flex-wrap: wrap !important; }
#dj-app-root .dj-app-pg-btn {
  width: 34px !important; height: 34px !important; border: 1.5px solid #e2e8f0 !important;
  border-radius: 6px !important; background: #fff !important; color: #475569 !important;
  font-size: 13px !important; font-weight: 600 !important; cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  transition: all .15s !important;
}
#dj-app-root .dj-app-pg-btn:hover { border-color: #2563eb !important; color: #2563eb !important; }
#dj-app-root .dj-app-pg-btn.active { background: #2563eb !important; border-color: #2563eb !important; color: #fff !important; }

/* ── Drawer ── */
#dj-app-root .dj-app-drawer-overlay {
  position: fixed !important; inset: 0 !important; background: rgba(15,23,42,.5) !important;
  z-index: 1000 !important; opacity: 0 !important; pointer-events: none !important;
  transition: opacity .25s !important; backdrop-filter: blur(2px) !important;
}
#dj-app-root .dj-app-drawer-overlay.open { opacity: 1 !important; pointer-events: all !important; }
#dj-app-root .dj-app-drawer {
  position: fixed !important; top: 0 !important; right: -680px !important;
  width: 660px !important; max-width: 95vw !important;
  height: 100vh !important; height: 100dvh !important;
  background: #fff !important; z-index: 1001 !important; overflow-y: auto !important;
  box-shadow: -8px 0 40px rgba(0,0,0,.18) !important;
  transition: right .28s cubic-bezier(.25,.8,.25,1) !important;
  display: flex !important; flex-direction: column !important;
}
#dj-app-root .dj-app-drawer.open { right: 0 !important; }
#dj-app-root .dj-app-drawer-header {
  display: flex !important; align-items: center !important; justify-content: flex-end !important;
  padding: 14px 20px !important; border-bottom: 1px solid #e2e8f0 !important;
  position: sticky !important; top: 0 !important; background: #fff !important; z-index: 1 !important; flex-shrink: 0 !important;
}
#dj-app-root .dj-app-drawer-close {
  width: 40px !important; height: 40px !important; border-radius: 50% !important;
  background: #334155 !important; border: none !important; cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  flex-shrink: 0 !important; transition: background .15s !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.18) !important; overflow: visible !important;
}
#dj-app-root .dj-app-drawer-close:hover { background: #1e293b !important; }
#dj-app-root .dj-app-drawer-close svg {
  display: block !important; width: 18px !important; height: 18px !important;
  fill: none !important; pointer-events: none !important; overflow: visible !important;
}
#dj-app-root .dj-app-drawer-close svg line {
  stroke: #ffffff !important; stroke-width: 2.5px !important; stroke-linecap: round !important;
}
#dj-app-root .dj-app-drawer-body { flex: 1 !important; padding: 22px 26px !important; overflow-y: auto !important; }
/* Drawer content */
#dj-app-root .dj-drawer-top { display: flex !important; align-items: flex-start !important; justify-content: space-between !important; gap: 12px !important; margin-bottom: 18px !important; flex-wrap: wrap !important; }
#dj-app-root .dj-drawer-top h2 { font-size: 20px !important; font-weight: 800 !important; color: #0f172a !important; margin-top: 4px !important; }
#dj-app-root .dj-drawer-meta { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(130px,1fr)) !important; gap: 8px !important; margin-bottom: 20px !important; }
#dj-app-root .dj-drawer-meta-item { background: #f8fafc !important; border-radius: 6px !important; padding: 10px 12px !important; }
#dj-app-root .dj-drawer-meta-item .m-label { font-size: 10px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .7px !important; color: #94a3b8 !important; display: block !important; margin-bottom: 3px !important; }
#dj-app-root .dj-drawer-meta-item .m-val { font-size: 13px !important; font-weight: 600 !important; color: #0f172a !important; display: block !important; }
#dj-app-root .dj-drawer-section { margin-bottom: 22px !important; }
#dj-app-root .dj-drawer-section-title { font-size: 11px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .8px !important; color: #94a3b8 !important; border-bottom: 1px solid #e2e8f0 !important; padding-bottom: 8px !important; margin-bottom: 12px !important; display: block !important; }
#dj-app-root .dj-drawer-desc { font-size: 13px !important; line-height: 1.75 !important; color: #475569 !important; white-space: pre-wrap !important; }
/* Photos */
#dj-app-root .dj-drawer-photos { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(80px,1fr)) !important; gap: 8px !important; }
#dj-app-root .dj-drawer-photo-thumb { aspect-ratio: 1 !important; border-radius: 6px !important; overflow: hidden !important; position: relative !important; }
#dj-app-root .dj-drawer-photo-thumb img { width: 100% !important; height: 100% !important; object-fit: cover !important; display: block !important; }
#dj-app-root .dj-drawer-photo-del { position: absolute !important; top: 3px !important; right: 3px !important; background: rgba(0,0,0,.65) !important; border: none !important; width: 20px !important; height: 20px !important; border-radius: 50% !important; color: #fff !important; font-size: 11px !important; cursor: pointer !important; display: none !important; align-items: center !important; justify-content: center !important; }
#dj-app-root .dj-drawer-photo-thumb:hover .dj-drawer-photo-del { display: flex !important; }
#dj-app-root .dj-drawer-upload-zone { display: flex !important; align-items: center !important; gap: 10px !important; padding: 10px 14px !important; border: 1.5px dashed #e2e8f0 !important; border-radius: 6px !important; cursor: pointer !important; transition: all .15s !important; margin-top: 10px !important; }
#dj-app-root .dj-drawer-upload-zone:hover { border-color: #2563eb !important; background: #eff6ff !important; }
#dj-app-root .dj-drawer-upload-zone span { font-size: 12px !important; color: #475569 !important; }

/* ── Upload placeholder thumbnails ── */
#dj-app-root .dj-photo-ph-shimmer {
  position: absolute !important; inset: 0 !important;
  background: linear-gradient(90deg, #e2e8f0 25%, #f1f5f9 50%, #e2e8f0 75%) !important;
  background-size: 200% 100% !important;
  animation: dj-shimmer 1.4s infinite !important;
}
@keyframes dj-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
#dj-app-root .dj-photo-ph-overlay {
  position: absolute !important; inset: 0 !important;
  display: flex !important; flex-direction: column !important;
  align-items: center !important; justify-content: center !important;
  gap: 3px !important;
}
#dj-app-root .dj-upload-ring {
  width: 36px !important; height: 36px !important;
  transform: rotate(-90deg) !important;
  overflow: visible !important;
}
#dj-app-root .dj-upload-ring-bg  { stroke: rgba(255,255,255,.35) !important; }
#dj-app-root .dj-upload-ring-fill {
  stroke: #ffffff !important;
  stroke-linecap: round !important;
  transition: stroke-dashoffset .25s ease !important;
}
#dj-app-root .dj-upload-pct {
  font-size: 10px !important; font-weight: 700 !important;
  color: #fff !important; line-height: 1 !important;
  text-shadow: 0 1px 3px rgba(0,0,0,.4) !important;
}
#dj-app-root .dj-photo-uploading .dj-photo-ph-overlay { background: rgba(15,23,42,.45) !important; }
#dj-app-root .dj-photo-error { border: 2px solid #dc2626 !important; }
#dj-app-root .dj-upload-count { font-size: 12px !important; }
/* Notes */
#dj-app-root .dj-drawer-notes { display: flex !important; flex-direction: column !important; gap: 12px !important; }
#dj-app-root .dj-drawer-note { display: flex !important; gap: 10px !important; }
#dj-app-root .dj-drawer-note-av { width: 30px !important; height: 30px !important; min-width: 30px !important; border-radius: 50% !important; background: linear-gradient(135deg,#2563eb,#7c3aed) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 11px !important; font-weight: 800 !important; color: #fff !important; }
#dj-app-root .dj-drawer-note-body { flex: 1 !important; background: #f8fafc !important; border-radius: 6px !important; padding: 10px 12px !important; }
#dj-app-root .dj-drawer-note-meta { display: flex !important; justify-content: space-between !important; margin-bottom: 4px !important; }
#dj-app-root .dj-drawer-note-author { font-size: 12px !important; font-weight: 700 !important; color: #0f172a !important; }
#dj-app-root .dj-drawer-note-date { font-size: 11px !important; color: #94a3b8 !important; }
#dj-app-root .dj-drawer-note-text { font-size: 13px !important; color: #475569 !important; line-height: 1.6 !important; }
#dj-app-root .dj-drawer-note-form { display: flex !important; flex-direction: column !important; gap: 8px !important; margin-top: 12px !important; }
#dj-app-root .dj-drawer-note-form textarea { width: 100% !important; padding: 10px 12px !important; border: 1.5px solid #e2e8f0 !important; border-radius: 6px !important; font-size: 13px !important; color: #0f172a !important; resize: none !important; outline: none !important; background: #fff !important; }
#dj-app-root .dj-drawer-note-form textarea:focus { border-color: #2563eb !important; }
/* Timeline */
#dj-app-root .dj-drawer-timeline { display: flex !important; flex-direction: column !important; }
#dj-app-root .dj-drawer-tl-item { display: flex !important; gap: 12px !important; padding-bottom: 14px !important; position: relative !important; }
#dj-app-root .dj-drawer-tl-item:not(:last-child)::before { content: '' !important; position: absolute !important; left: 7px !important; top: 18px !important; bottom: 0 !important; width: 2px !important; background: #e2e8f0 !important; }
#dj-app-root .dj-drawer-tl-dot { width: 16px !important; height: 16px !important; min-width: 16px !important; border-radius: 50% !important; background: #2563eb !important; border: 3px solid #fff !important; box-shadow: 0 0 0 2px #e2e8f0 !important; margin-top: 2px !important; }
#dj-app-root .dj-drawer-tl-text { font-size: 13px !important; color: #475569 !important; line-height: 1.5 !important; }
#dj-app-root .dj-drawer-tl-date { font-size: 11px !important; color: #94a3b8 !important; margin-top: 2px !important; }
#dj-app-root .dj-drawer-edit-section { border-top: 1px solid #e2e8f0 !important; padding-top: 20px !important; margin-top: 4px !important; }
#dj-app-root .dj-drawer-edit-section.hidden { display: none !important; }

/* ── Calendar ── */
#dj-app-root .dj-app-calendar { background: #fff !important; border: 1px solid #e2e8f0 !important; border-radius: 10px !important; overflow: hidden !important; }
#dj-app-root .dj-cal-day-names { display: grid !important; grid-template-columns: repeat(7,1fr) !important; background: #f8fafc !important; border-bottom: 1px solid #e2e8f0 !important; }
#dj-app-root .dj-cal-day-name { text-align: center !important; padding: 10px !important; font-size: 11px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .7px !important; color: #94a3b8 !important; }
#dj-app-root .dj-cal-grid { display: grid !important; grid-template-columns: repeat(7,1fr) !important; }
#dj-app-root .dj-cal-cell { min-height: 100px !important; border-right: 1px solid #e2e8f0 !important; border-bottom: 1px solid #e2e8f0 !important; padding: 7px 5px !important; }
#dj-app-root .dj-cal-cell:nth-child(7n) { border-right: none !important; }
#dj-app-root .dj-cal-cell.other-month { background: #f8fafc !important; opacity: .6 !important; }
#dj-app-root .dj-cal-date { font-size: 12px !important; font-weight: 600 !important; color: #475569 !important; width: 26px !important; height: 26px !important; display: flex !important; align-items: center !important; justify-content: center !important; margin-bottom: 4px !important; }
#dj-app-root .dj-cal-cell.today .dj-cal-date { background: #2563eb !important; color: #fff !important; border-radius: 50% !important; }
#dj-app-root .dj-cal-ev { font-size: 11px !important; padding: 3px 7px !important; border-radius: 4px !important; margin-bottom: 3px !important; cursor: pointer !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; font-weight: 600 !important; border-left: 3px solid transparent !important; display: block !important; transition: filter .15s !important; }
#dj-app-root .dj-cal-ev:hover { filter: brightness(.9) !important; }
#dj-app-root .dj-cal-ev.is-due { border-style: dashed !important; background: transparent !important; opacity: .8 !important; }
#dj-app-root .dj-cal-more { font-size: 10px !important; color: #94a3b8 !important; font-weight: 600 !important; cursor: pointer !important; padding: 2px 4px !important; display: block !important; }

/* ── Tracker ── */
#dj-app-root .dj-app-tracker-wrap { max-width: 680px !important; }
#dj-app-root .dj-app-tracker-search { display: flex !important; gap: 10px !important; margin-bottom: 20px !important; }
#dj-app-root .dj-app-tracker-search input { flex: 1 !important; padding: 12px 16px !important; border: 1.5px solid #e2e8f0 !important; border-radius: 8px !important; font-size: 14px !important; color: #0f172a !important; background: #fff !important; outline: none !important; }
#dj-app-root .dj-app-tracker-search input:focus { border-color: #2563eb !important; }

/* ── Buttons ── */
#dj-app-root .dj-app-btn {
  display: inline-flex !important; align-items: center !important; gap: 7px !important;
  padding: 9px 18px !important; border-radius: 6px !important; font-size: 13px !important;
  font-weight: 600 !important; cursor: pointer !important; transition: all .15s !important;
  line-height: 1 !important; border: 1.5px solid transparent !important; text-decoration: none !important;
  white-space: nowrap !important;
}
#dj-app-root .dj-app-btn-primary { background: #2563eb !important; color: #fff !important; border-color: #2563eb !important; }
#dj-app-root .dj-app-btn-primary:hover { background: #1d4ed8 !important; border-color: #1d4ed8 !important; color: #fff !important; transform: translateY(-1px) !important; box-shadow: 0 4px 12px rgba(37,99,235,.3) !important; }
#dj-app-root .dj-app-btn-secondary { background: #f8fafc !important; color: #475569 !important; border-color: #e2e8f0 !important; }
#dj-app-root .dj-app-btn-secondary:hover { background: #e2e8f0 !important; color: #0f172a !important; }
#dj-app-root .dj-app-btn-outline { background: transparent !important; color: #475569 !important; border-color: #e2e8f0 !important; }
#dj-app-root .dj-app-btn-outline:hover { border-color: #2563eb !important; color: #2563eb !important; }
#dj-app-root .dj-app-btn-outline.active { background: #eff6ff !important; border-color: #2563eb !important; color: #2563eb !important; }
#dj-app-root .dj-app-btn-danger { background: transparent !important; color: #dc2626 !important; border-color: #dc2626 !important; }
#dj-app-root .dj-app-btn-danger:hover, #dj-app-root .dj-app-btn-danger-outline:hover { background: #dc2626 !important; color: #fff !important; }
#dj-app-root .dj-app-btn-danger-outline { background: transparent !important; color: #dc2626 !important; border-color: #dc2626 !important; }
#dj-app-root .dj-app-btn-sm { padding: 5px 10px !important; font-size: 12px !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 4px !important; line-height: 1 !important; }
#dj-app-root .dj-app-btn-sm svg { flex-shrink: 0; display: block; }
#dj-app-root .dj-app-row-actions .dj-app-btn-sm { padding: 5px 8px !important; }
#dj-app-root .dj-app-btn-lg { padding: 12px 24px !important; font-size: 15px !important; }
#dj-app-root .dj-app-btn-full { width: 100% !important; justify-content: center !important; }
#dj-app-root .dj-app-btn:disabled { opacity: .5 !important; cursor: not-allowed !important; transform: none !important; box-shadow: none !important; }

/* ── Forms ── */
#dj-app-root .dj-app-form-wrap { max-width: 720px !important; }
#dj-app-root .dj-app-job-form { background: #fff !important; border: 1px solid #e2e8f0 !important; border-radius: 10px !important; padding: 24px 26px !important; }
#dj-app-root .dj-app-form-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 14px !important; }
#dj-app-root .dj-app-field { display: flex !important; flex-direction: column !important; gap: 5px !important; }
#dj-app-root .dj-app-field-full { grid-column: 1 / -1 !important; }
#dj-app-root .dj-app-field label { font-size: 11px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .6px !important; color: #475569 !important; margin-bottom: 0 !important; }
#dj-app-root .dj-app-input {
  padding: 10px 13px !important; border: 1.5px solid #e2e8f0 !important; border-radius: 6px !important;
  font-size: 13px !important; color: #0f172a !important; background: #fff !important;
  outline: none !important; transition: border-color .18s !important; width: 100% !important;
  box-shadow: none !important; -webkit-text-fill-color: #0f172a !important;
}
#dj-app-root .dj-app-input:focus { border-color: #2563eb !important; box-shadow: 0 0 0 3px rgba(37,99,235,.1) !important; }
#dj-app-root .dj-app-input::placeholder { color: #94a3b8 !important; opacity: 1 !important; }
#dj-app-root .dj-app-textarea { resize: vertical !important; min-height: 90px !important; line-height: 1.6 !important; }
#dj-app-root .dj-app-form-actions { display: flex !important; align-items: center !important; gap: 12px !important; margin-top: 20px !important; padding-top: 16px !important; padding-bottom: 80px !important; border-top: 1px solid #e2e8f0 !important; flex-wrap: wrap !important; }
#dj-app-root .dj-app-form-notice { font-size: 13px !important; margin-left: auto !important; }

/* ── Modals ── */
#dj-app-root .dj-app-modal-backdrop {
  position: fixed !important; inset: 0 !important; background: rgba(15,23,42,.6) !important;
  z-index: 2000 !important; display: flex !important; align-items: center !important;
  justify-content: center !important; padding: 20px !important; backdrop-filter: blur(3px) !important;
}
#dj-app-root .dj-app-modal-header { display: flex !important; align-items: center !important; justify-content: space-between !important; padding: 20px 24px 16px !important; border-bottom: 1px solid #e2e8f0 !important; }
#dj-app-root .dj-app-modal-header h3 { font-size: 17px !important; font-weight: 800 !important; color: #0f172a !important; }
#dj-app-root .dj-app-modal { position: relative !important; background: #fff !important; border-radius: 14px !important; width: 100% !important; max-width: 520px !important; box-shadow: 0 8px 32px rgba(0,0,0,.16) !important; }
#dj-app-root .dj-app-modal-close { background: none !important; border: none !important; cursor: pointer !important; color: #94a3b8 !important; padding: 8px !important; border-radius: 50% !important; transition: all .15s !important; min-width: 36px !important; min-height: 36px !important; display: flex !important; align-items: center !important; justify-content: center !important; -webkit-tap-highlight-color: transparent !important; }
#dj-app-root .dj-app-modal-close:hover { background: #f8fafc !important; color: #0f172a !important; }
#dj-app-root .dj-app-modal-body { padding: 18px 24px !important; }
#dj-app-root .dj-app-modal-footer { padding: 14px 24px !important; border-top: 1px solid #e2e8f0 !important; display: flex !important; justify-content: flex-end !important; gap: 10px !important; }
#dj-app-root .dj-app-info-box { background: #eff6ff !important; border: 1px solid #bfdbfe !important; border-radius: 6px !important; padding: 12px 14px !important; font-size: 12px !important; color: #2563eb !important; margin-top: 14px !important; line-height: 1.6 !important; }

/* ── Loading / Empty / Spinner ── */
#dj-app-root .dj-app-loading { display: flex !important; align-items: center !important; justify-content: center !important; gap: 10px !important; padding: 48px !important; color: #94a3b8 !important; font-size: 13px !important; }
#dj-app-root .dj-app-spinner { width: 22px !important; height: 22px !important; border: 2px solid #e2e8f0 !important; border-top-color: #2563eb !important; border-radius: 50% !important; animation: dja-spin .7s linear infinite !important; flex-shrink: 0 !important; }
#dj-app-root .dj-app-spinner-sm { width: 14px !important; height: 14px !important; border: 2px solid rgba(255,255,255,.3) !important; border-top-color: #fff !important; border-radius: 50% !important; animation: dja-spin .7s linear infinite !important; display: inline-block !important; }
#dj-app-root .dj-app-empty { text-align: center !important; padding: 60px 20px !important; color: #94a3b8 !important; }
#dj-app-root .dj-app-empty h3 { font-size: 15px !important; font-weight: 600 !important; color: #0f172a !important; margin-bottom: 6px !important; }
#dj-app-root .dj-app-empty p { font-size: 13px !important; }

/* ── Toasts ── */
.dj-app-toasts { position: fixed !important; bottom: 20px !important; right: 20px !important; z-index: 9999 !important; display: flex !important; flex-direction: column !important; gap: 8px !important; pointer-events: none !important; }
.dj-app-toast { background: #0f172a !important; color: #fff !important; padding: 12px 18px !important; border-radius: 6px !important; font-family: 'Inter',sans-serif !important; font-size: 13px !important; font-weight: 500 !important; box-shadow: 0 8px 32px rgba(0,0,0,.16) !important; max-width: 320px !important; animation: dja-toast-in .2s ease !important; pointer-events: all !important; }
.dj-app-toast-success { background: #15803d !important; }
.dj-app-toast-error   { background: #b91c1c !important; }

/* ── Animations ── */
@keyframes dja-spin     { to { transform: rotate(360deg); } }
@keyframes dja-toast-in { from { opacity:0; transform: translateX(20px); } to { opacity:1; transform:none; } }

/* ── Mobile ── */
#dj-app-nav-toggle {
  display: none !important; position: fixed !important; top: 14px !important; left: 14px !important;
  z-index: 1100 !important; width: 44px !important; height: 44px !important;
  background: #1e293b !important; border: 2px solid rgba(255,255,255,.15) !important;
  border-radius: 10px !important; color: #fff !important;
  align-items: center !important; justify-content: center !important;
  cursor: pointer !important; box-shadow: 0 2px 12px rgba(0,0,0,.5) !important;
  flex-direction: column !important; gap: 5px !important; padding: 10px !important;
}
/* Hamburger lines are injected as divs by JS */
#dj-app-nav-toggle div {
  width: 20px !important; height: 2px !important;
  background: #ffffff !important; border-radius: 2px !important;
  display: block !important; flex-shrink: 0 !important;
  pointer-events: none !important;
}
@media (max-width: 768px) {
  #dj-app-root .dj-app-shell { flex-direction: column !important; position: relative !important; }
  #dj-app-root .dj-app-nav {
    position: fixed !important; left: 0 !important; top: 0 !important; bottom: 0 !important;
    transform: translateX(-100%) !important; transition: transform .25s ease !important;
    z-index: 1050 !important; min-height: 100vh !important; width: 220px !important;
  }
  #dj-app-root .dj-app-nav.open { transform: translateX(0) !important; box-shadow: 4px 0 24px rgba(0,0,0,.4) !important; }
  #dj-app-root .dj-app-content { padding: 60px 16px 16px !important; }
  #dj-app-root .dj-app-form-grid { grid-template-columns: 1fr !important; }
  #dj-app-root .dj-cal-cell { min-height: 64px !important; padding: 3px !important; }
  #dj-app-root .dj-cal-ev { font-size: 9px !important; padding: 1px 4px !important; }
  #dj-app-root .dj-app-drawer { width: 100% !important; max-width: 100% !important; right: -100% !important; height: 100vh !important; height: 100dvh !important; }
  #dj-app-root .dj-app-drawer-body { padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 100px) !important; }
  #dj-app-nav-toggle { display: flex !important; }
}

/* ── Assignee Chip Picker ── */
#dj-app-root .dj-assignee-picker {
  display: flex !important; flex-wrap: wrap !important; gap: 8px !important; padding: 4px 0 !important;
}
#dj-app-root .dj-assignee-chip {
  display: inline-flex !important; align-items: center !important; gap: 6px !important;
  padding: 6px 12px 6px 6px !important; border-radius: 20px !important; cursor: pointer !important;
  border: 1.5px solid #e2e8f0 !important; background: #f8fafc !important;
  transition: all .15s !important; user-select: none !important; -webkit-user-select: none !important;
}
#dj-app-root .dj-assignee-chip:hover { border-color: #2563eb !important; background: #eff6ff !important; }
#dj-app-root .dj-assignee-chip.selected {
  border-color: #2563eb !important; background: #2563eb !important;
}
#dj-app-root .dj-assignee-chip.selected .dj-assignee-chip-name { color: #fff !important; }
#dj-app-root .dj-assignee-chip-av {
  width: 22px !important; height: 22px !important; border-radius: 50% !important;
  background: linear-gradient(135deg, #6366f1, #7c3aed) !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-size: 9px !important; font-weight: 800 !important; color: #fff !important; flex-shrink: 0 !important;
}
#dj-app-root .dj-assignee-chip.selected .dj-assignee-chip-av { background: rgba(255,255,255,.25) !important; }
#dj-app-root .dj-assignee-chip-name { font-size: 12px !important; font-weight: 600 !important; color: #0f172a !important; white-space: nowrap !important; }

/* ══════════════════════════════════════════════
   MOBILE JOBS DASHBOARD  (max-width: 640px)
   ══════════════════════════════════════════════ */
@media (max-width: 640px) {

  /* ── Panel header ── */
  #dj-app-root .dj-app-panel-header { margin-bottom: 14px !important; }
  #dj-app-root .dj-app-panel-header h2 { font-size: 18px !important; }
  #dj-app-root .dj-app-btn svg { flex-shrink: 0 !important; }

  /* ── Stat bar: horizontal scroll strip ── */
  #dj-app-root .dj-app-stat-bar {
    display: flex !important; flex-wrap: nowrap !important;
    overflow-x: auto !important; gap: 8px !important;
    padding-bottom: 6px !important; margin-bottom: 14px !important;
    -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important;
  }
  #dj-app-root .dj-app-stat-bar::-webkit-scrollbar { display: none !important; }
  #dj-app-root .dj-app-stat {
    flex: 0 0 auto !important; min-width: 76px !important;
    padding: 10px 12px !important;
  }
  #dj-app-root .dj-app-stat-num { font-size: 18px !important; }
  #dj-app-root .dj-app-stat-label { font-size: 9px !important; }

  /* ── Search ── */
  #dj-app-root .dj-app-search-wrap input { font-size: 16px !important; } /* prevent iOS zoom */

  /* ── Filters: hide dropdowns by default, shown via toggle ── */

  /* Filter toggle button */

  /* ── Status pills: horizontal scroll, no wrap ── */
  #dj-app-root .dj-app-pills {
    flex-wrap: nowrap !important; overflow-x: auto !important;
    padding-bottom: 4px !important; gap: 6px !important;
    -webkit-overflow-scrolling: touch !important; scrollbar-width: none !important;
  }
  #dj-app-root .dj-app-pills::-webkit-scrollbar { display: none !important; }
  #dj-app-root .dj-app-pill { flex-shrink: 0 !important; padding: 6px 13px !important; }

  /* ── Table → Card layout ── */
  #dj-app-root .dj-app-table-wrap { border-radius: 10px !important; overflow: visible !important; border: none !important; background: transparent !important; }
  #dj-app-root .dj-app-table { display: block !important; }
  #dj-app-root .dj-app-table thead { display: none !important; }
  #dj-app-root .dj-app-table tbody { display: flex !important; flex-direction: column !important; gap: 8px !important; }
  #dj-app-root .dj-app-table tbody tr {
    display: flex !important; flex-direction: column !important;
    background: #fff !important; border: 1px solid #e2e8f0 !important;
    border-radius: 10px !important; padding: 14px 16px !important;
    cursor: pointer !important; transition: box-shadow .15s !important;
    border-bottom: 1px solid #e2e8f0 !important;
  }
  #dj-app-root .dj-app-table tbody tr:hover { box-shadow: 0 2px 12px rgba(0,0,0,.08) !important; border-color: #cbd5e1 !important; }

  /* Jobs table — card layout on mobile */
  /* Scope all block/hide rules to the jobs table only, not customers */
  #dj-app-root #dj-app-jobs-table .dj-app-table td { display: block !important; padding: 0 !important; }

  /* Hide columns we don't need on mobile */
  /* Columns: 1=Title, 2=Status, 3=Priority, 4=Assigned, 5=Scheduled, 6=Due, 7=Billing, 8=Actions */
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(4), /* Assigned */
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(5), /* Scheduled */
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(6), /* Due */
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(8)  /* Actions */
  { display: none !important; }

  /* Billing badge — show inline next to status/priority */
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(7) {
    display: inline-block !important; vertical-align: middle !important;
    margin-top: 6px !important; margin-left: 8px !important;
  }

  /* Title cell */
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(1) { margin-bottom: 10px !important; }
  #dj-app-root .dj-app-job-title { font-size: 15px !important; font-weight: 700 !important; }
  #dj-app-root .dj-app-job-loc { font-size: 12px !important; margin-top: 3px !important; }
  #dj-app-root .dj-app-job-num {
    display: block !important; font-size: 10px !important;
    color: #94a3b8 !important; margin-bottom: 3px !important;
    font-family: monospace !important;
  }

  /* Status + Priority + Billing inline */
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(2),
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(3) {
    display: inline-block !important; vertical-align: middle !important;
    margin-top: 6px !important;
  }
  #dj-app-root #dj-app-jobs-table .dj-app-table td:nth-child(2) { margin-right: 10px !important; }

  /* Customers table mobile */
  /* Customer table mobile — inherited from desktop rules above */
  #dj-app-root .dj-app-customers-table .dj-cust-main-row td { padding: 0 !important; border: none !important; }
  /* Detail row — hidden by default, .cust-open class added by JS when expanded */
  #dj-app-root .dj-app-customers-table .dj-cust-detail-row { display: none !important; }
  #dj-app-root .dj-app-customers-table .dj-cust-detail-row.cust-open {
    display: block !important;
  }
  #dj-app-root .dj-app-customers-table .dj-cust-detail-row.cust-open td {
    display: block !important; padding: 0 !important; width: 100% !important;
  }

  /* ── Pagination ── */
  #dj-app-root .dj-app-pagination { gap: 4px !important; }
  #dj-app-root .dj-app-pg-btn { width: 38px !important; height: 38px !important; font-size: 14px !important; }

  /* ── New Job button — full width on mobile ── */
  #dj-app-root #dj-app-new-job-btn { width: 100% !important; justify-content: center !important; font-size: 14px !important; padding: 11px !important; }
  #dj-app-root .dj-app-panel-header { flex-direction: column !important; align-items: stretch !important; }
}

/* (mobile job# now inline in title cell via JS — no extra rule needed) */

/* ── Billing section in job form ── */
#dj-app-root .dj-app-billing-section {
  margin-top: 20px !important;
  border-top: 1px solid #e2e8f0 !important;
  padding-top: 18px !important;
}
#dj-app-root .dj-app-billing-heading {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--dja-muted, #64748b) !important;
  margin-bottom: 14px !important;
}
#dj-app-root .dj-app-input-prefix-wrap {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}
#dj-app-root .dj-app-input-prefix {
  position: absolute !important;
  left: 11px !important;
  font-size: 13px !important;
  color: var(--dja-muted, #64748b) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}
#dj-app-root .dj-app-input-prefixed {
  padding-left: 24px !important;
}
#dj-app-root input[readonly].dj-app-input-prefixed {
  background: #f8fafc !important;
  color: var(--dja-muted, #64748b) !important;
  cursor: default !important;
}

/* ── Billing card in job drawer ── */
#dj-app-root .dj-drawer-billing {
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 10px !important;
  padding: 14px 16px !important;
  margin-bottom: 20px !important;
}
#dj-app-root .dj-drawer-billing-heading {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--dja-muted, #64748b) !important;
  margin-bottom: 12px !important;
}
#dj-app-root .dj-drawer-billing-row {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 12px !important;
  margin-bottom: 12px !important;
}
#dj-app-root .dj-drawer-billing-item {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}
#dj-app-root .dj-drawer-billing-item span {
  font-size: 11px !important;
  color: var(--dja-muted, #64748b) !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}
#dj-app-root .dj-drawer-billing-item strong {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--dja-text, #0f172a) !important;
}
#dj-app-root .dj-drawer-billing-bar {
  height: 5px !important;
  background: #e2e8f0 !important;
  border-radius: 99px !important;
  overflow: hidden !important;
  margin-bottom: 5px !important;
}
#dj-app-root .dj-drawer-billing-bar-fill {
  height: 100% !important;
  background: var(--dja-success, #16a34a) !important;
  border-radius: 99px !important;
  transition: width .4s ease !important;
}
#dj-app-root .dj-drawer-billing-bar-label {
  font-size: 11px !important;
  color: var(--dja-muted, #64748b) !important;
  text-align: right !important;
}

/* ── Settings tab ── */
#dj-app-root .dj-settings-wrap {
  max-width: 680px !important;
}
#dj-app-root .dj-settings-section {
  background: #fff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 12px !important;
  padding: 24px !important;
  margin-bottom: 20px !important;
}
#dj-app-root .dj-settings-heading {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--dja-text, #0f172a) !important;
  margin-bottom: 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid #f1f5f9 !important;
}
#dj-app-root .dj-settings-logo-area {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}
#dj-app-root .dj-settings-logo-preview {
  width: 100% !important;
  max-width: 320px !important;
  height: 120px !important;
  border: 2px dashed #e2e8f0 !important;
  border-radius: 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #f8fafc !important;
  color: #94a3b8 !important;
  font-size: 12px !important;
  text-align: center !important;
  overflow: hidden !important;
  padding: 12px !important;
}
#dj-app-root .dj-settings-logo-preview img {
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
}
#dj-app-root .dj-settings-logo-actions {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}

/* ── Invoice button in drawer ── */
#dj-app-root #dj-drawer-invoice-btn {
  background: #f0fdf4 !important;
  border-color: #16a34a !important;
  color: #16a34a !important;
}
#dj-app-root #dj-drawer-invoice-btn:hover {
  background: #16a34a !important;
  color: #fff !important;
}

/* ── Note edit/delete actions ── */
#dj-app-root .dj-drawer-note-meta {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin-bottom: 6px !important;
}
#dj-app-root .dj-note-actions {
  display: flex !important;
  gap: 4px !important;
  opacity: 0 !important;
  transition: opacity .15s !important;
  flex-shrink: 0 !important;
}
#dj-app-root .dj-drawer-note:hover .dj-note-actions,
#dj-app-root .dj-drawer-note:focus-within .dj-note-actions {
  opacity: 1 !important;
}
#dj-app-root .dj-note-btn {
  width: 24px !important; height: 24px !important;
  border-radius: 6px !important; border: none !important;
  background: transparent !important; cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: var(--dja-muted, #64748b) !important;
  transition: background .12s, color .12s !important;
  padding: 0 !important;
}
#dj-app-root .dj-note-btn:hover { background: #f1f5f9 !important; color: var(--dja-text,#0f172a) !important; }
#dj-app-root .dj-note-del-btn:hover { background: #fee2e2 !important; color: #dc2626 !important; }
/* Mobile: always show actions */
@media (max-width: 640px) {
  #dj-app-root .dj-note-actions { opacity: 1 !important; }
}
/* Inline edit form */
#dj-app-root .dj-note-edit-form { margin-top: 8px !important; }
#dj-app-root .dj-note-edit-ta {
  width: 100% !important; padding: 8px 10px !important;
  border: 1.5px solid #2563eb !important; border-radius: 6px !important;
  font-size: 13px !important; line-height: 1.6 !important;
  resize: vertical !important; min-height: 72px !important;
  font-family: inherit !important; color: var(--dja-text,#0f172a) !important;
  box-sizing: border-box !important;
}
#dj-app-root .dj-note-edit-ta:focus { outline: none !important; box-shadow: 0 0 0 3px rgba(37,99,235,.15) !important; }
#dj-app-root .dj-note-edit-actions {
  display: flex !important; gap: 8px !important; margin-top: 6px !important;
}

/* ── Agenda / list view ── */
#dj-app-root .dj-agenda-list {
  display: flex !important;
  flex-direction: column !important;
}
#dj-app-root .dj-agenda-row {
  display: flex !important;
  gap: 0 !important;
  border-bottom: 1px solid #f1f5f9 !important;
  min-height: 48px !important;
}
#dj-app-root .dj-agenda-today {
  background: #eff6ff !important;
}
#dj-app-root .dj-agenda-date-col {
  width: 52px !important;
  min-width: 52px !important;
  padding: 12px 8px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  border-right: 1px solid #f1f5f9 !important;
  flex-shrink: 0 !important;
}
#dj-app-root .dj-agenda-dow {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  color: #94a3b8 !important;
  line-height: 1 !important;
  margin-bottom: 4px !important;
}
#dj-app-root .dj-agenda-day {
  font-size: 18px !important;
  font-weight: 600 !important;
  color: #334155 !important;
  line-height: 1 !important;
}
#dj-app-root .dj-agenda-day-today span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 32px !important;
  height: 32px !important;
  background: #2563eb !important;
  color: #fff !important;
  border-radius: 50% !important;
  font-size: 16px !important;
}
#dj-app-root .dj-agenda-events {
  flex: 1 !important;
  padding: 10px 12px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  min-width: 0 !important;
}
#dj-app-root .dj-agenda-ev {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 8px 10px !important;
  border-radius: 8px !important;
  background: #f8fafc !important;
  border-left: 3px solid #94a3b8 !important;
  cursor: pointer !important;
  transition: background .12s !important;
  min-width: 0 !important;
}
#dj-app-root .dj-agenda-ev:hover { background: #f1f5f9 !important; }
#dj-app-root .dj-agenda-ev-dot {
  width: 8px !important;
  height: 8px !important;
  min-width: 8px !important;
  border-radius: 50% !important;
}
#dj-app-root .dj-agenda-ev-body {
  flex: 1 !important;
  min-width: 0 !important;
}
#dj-app-root .dj-agenda-ev-title {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #0f172a !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
#dj-app-root .dj-agenda-ev-time {
  font-size: 11px !important;
  color: #64748b !important;
  margin-top: 2px !important;
}
#dj-app-root .dj-agenda-ev-badge {
  font-size: 10px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  padding: 2px 7px !important;
  border-radius: 99px !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
#dj-app-root .dj-agenda-empty-day {
  font-size: 12px !important;
  color: #94a3b8 !important;
  font-style: italic !important;
}
#dj-app-root .dj-agenda-no-events {
  padding: 48px 24px !important;
  text-align: center !important;
  color: #94a3b8 !important;
}
#dj-app-root .dj-agenda-no-events svg { margin-bottom: 12px !important; }
#dj-app-root .dj-agenda-no-events p { font-size: 14px !important; }

/* ── Share button in drawer ── */
#dj-app-root #dj-drawer-share-btn {
  background: #eff6ff !important;
  border-color: #2563eb !important;
  color: #2563eb !important;
}
#dj-app-root #dj-drawer-share-btn:hover {
  background: #2563eb !important;
  color: #fff !important;
}

/* ── Settings toggle switch ── */
#dj-app-root .dj-settings-toggle-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 20px !important;
}
#dj-app-root .dj-settings-toggle-info { flex: 1 !important; }
#dj-app-root .dj-toggle-switch {
  position: relative !important;
  display: inline-block !important;
  width: 44px !important;
  height: 24px !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
}
#dj-app-root .dj-toggle-switch input { opacity: 0 !important; width: 0 !important; height: 0 !important; }
#dj-app-root .dj-toggle-knob {
  position: absolute !important;
  inset: 0 !important;
  background: #e2e8f0 !important;
  border-radius: 99px !important;
  transition: background .2s !important;
}
#dj-app-root .dj-toggle-knob::before {
  content: '' !important;
  position: absolute !important;
  width: 18px !important; height: 18px !important;
  left: 3px !important; top: 3px !important;
  background: #fff !important;
  border-radius: 50% !important;
  transition: transform .2s !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.2) !important;
}
#dj-app-root .dj-toggle-switch input:checked + .dj-toggle-knob { background: #2563eb !important; }
#dj-app-root .dj-toggle-switch input:checked + .dj-toggle-knob::before { transform: translateX(20px) !important; }

/* ── Revenue Dashboard ── */
#dj-app-root .dj-revenue-dash {
  margin-bottom: 18px !important;
}
#dj-app-root .dj-revenue-cards {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 10px !important;
  margin-bottom: 12px !important;
}
#dj-app-root .dj-revenue-card {
  background: #fff !important;
  border: 1px solid #e2e8f0 !important;
  border-radius: 12px !important;
  padding: 14px 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,.05) !important;
}
#dj-app-root .dj-revenue-card-icon {
  width: 40px !important; height: 40px !important;
  border-radius: 10px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  flex-shrink: 0 !important;
}
#dj-app-root .dj-rc-blue   { background: #eff6ff !important; color: #2563eb !important; }
#dj-app-root .dj-rc-green  { background: #f0fdf4 !important; color: #16a34a !important; }
#dj-app-root .dj-rc-red    { background: #fef2f2 !important; color: #dc2626 !important; }
#dj-app-root .dj-rc-purple { background: #f5f3ff !important; color: #7c3aed !important; }
#dj-app-root .dj-revenue-card-body { min-width: 0 !important; }
#dj-app-root .dj-revenue-card-val {
  font-size: 18px !important; font-weight: 800 !important;
  color: var(--dja-text, #0f172a) !important; line-height: 1.1 !important;
  white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
}
#dj-app-root .dj-revenue-card-label {
  font-size: 10px !important; font-weight: 700 !important;
  text-transform: uppercase !important; letter-spacing: .06em !important;
  color: var(--dja-muted, #94a3b8) !important; margin-top: 3px !important;
}
#dj-app-root .dj-revenue-bar-wrap { background: #fff !important; border: 1px solid #e2e8f0 !important; border-radius: 12px !important; padding: 12px 16px !important; }
#dj-app-root .dj-revenue-bar-meta {
  display: flex !important; justify-content: space-between !important;
  align-items: center !important; margin-bottom: 8px !important; flex-wrap: wrap !important; gap: 4px !important;
}
#dj-app-root .dj-revenue-bar {
  height: 8px !important; background: #e2e8f0 !important;
  border-radius: 99px !important; overflow: hidden !important;
}
#dj-app-root .dj-revenue-bar-fill {
  height: 100% !important; background: linear-gradient(90deg, #16a34a, #22c55e) !important;
  border-radius: 99px !important; transition: width .5s ease !important;
}
@media (max-width: 768px) {
  #dj-app-root .dj-revenue-cards { grid-template-columns: repeat(2, 1fr) !important; }
  #dj-app-root .dj-revenue-card-val { font-size: 15px !important; }
  #dj-app-root .dj-revenue-bar-meta { flex-direction: column !important; align-items: flex-start !important; }
}
@media (max-width: 480px) {
  #dj-app-root .dj-revenue-cards { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
  #dj-app-root .dj-revenue-card { padding: 10px 12px !important; gap: 8px !important; }
  #dj-app-root .dj-revenue-card-icon { width: 32px !important; height: 32px !important; border-radius: 8px !important; }
  #dj-app-root .dj-revenue-card-val { font-size: 13px !important; }
}

/* ── Jobs table billing status ── */
#dj-app-root .dj-bill-paid {
  display: inline-flex !important; align-items: center !important; gap: 4px !important;
  font-size: 11px !important; font-weight: 700 !important;
  color: #16a34a !important; background: #f0fdf4 !important;
  padding: 3px 8px !important; border-radius: 99px !important;
  border: 1px solid #bbf7d0 !important; white-space: nowrap !important;
}
#dj-app-root .dj-bill-due {
  display: inline-flex !important; align-items: center !important; gap: 4px !important;
  font-size: 11px !important; font-weight: 700 !important;
  color: #dc2626 !important; background: #fef2f2 !important;
  padding: 3px 8px !important; border-radius: 99px !important;
  border: 1px solid #fecaca !important; white-space: nowrap !important;
}
/* ── Customer expand panel ── */
#dj-app-root .dj-cust-chevron {
  font-size: 14px !important; color: #94a3b8 !important;
  width: 18px !important; flex-shrink: 0 !important;
  transition: transform .2s !important;
}
/* Customer table — full reset (rows are self-contained flex layouts) */
#dj-app-root .dj-app-customers-table { border-collapse: collapse !important; width: 100% !important; }
#dj-app-root .dj-app-customers-table thead { display: none !important; }
#dj-app-root .dj-app-customers-table tbody tr.dj-cust-main-row td {
  padding: 0 !important; border: none !important;
}
#dj-app-root .dj-app-customers-table tbody tr.dj-cust-main-row {
  border-bottom: 1px solid #f1f5f9 !important;
}
#dj-app-root .dj-cust-main-row:hover { background: #f8fafc !important; }
/* Customer row inner layout */
#dj-app-root .dj-cust-row-inner {
  display: flex !important; align-items: center !important;
  gap: 10px !important; padding: 12px 14px !important; width: 100% !important;
}
#dj-app-root .dj-cust-row-body {
  flex: 1 !important; min-width: 0 !important;
}
#dj-app-root .dj-cust-row-name {
  font-size: 14px !important; font-weight: 600 !important; color: #0f172a !important;
  white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
  display: flex !important; align-items: center !important; gap: 6px !important;
}
#dj-app-root .dj-cust-id-badge {
  font-size: 10px !important; font-weight: 700 !important; font-family: monospace !important;
  color: #94a3b8 !important; background: #f1f5f9 !important;
  padding: 1px 5px !important; border-radius: 4px !important;
  flex-shrink: 0 !important; letter-spacing: .02em !important;
}
#dj-app-root .dj-cust-row-sub {
  font-size: 11px !important; color: #94a3b8 !important; margin-top: 2px !important;
  white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
}
#dj-app-root .dj-cust-actions {
  display: flex !important; gap: 6px !important; flex-shrink: 0 !important;
  align-items: center !important; margin-left: auto !important;
}
#dj-app-root .dj-cust-detail-row > td { padding: 0 !important; border-top: none !important; }
#dj-app-root .dj-cust-expand-panel {
  padding: 16px 20px !important;
  background: #f8fafc !important;
  border-top: 1px solid #f1f5f9 !important;
}
#dj-app-root .dj-cust-expand-loading {
  display: flex !important; align-items: center !important; gap: 8px !important;
  font-size: 12px !important; color: #94a3b8 !important;
}
#dj-app-root .dj-cust-qr-card {
  display: flex !important; align-items: flex-start !important;
  gap: 16px !important; flex-wrap: wrap !important;
}
#dj-app-root .dj-cust-qr-info { flex: 1 !important; min-width: 200px !important; }
#dj-app-root .dj-cust-qr-label {
  font-size: 10px !important; font-weight: 800 !important;
  text-transform: uppercase !important; letter-spacing: .08em !important;
  color: #94a3b8 !important; margin-bottom: 6px !important;
}
#dj-app-root .dj-cust-qr-url {
  font-size: 11px !important; color: #64748b !important;
  word-break: break-all !important; line-height: 1.5 !important;
  margin-bottom: 4px !important;
}
/* Customer no-portal placeholder */
#dj-app-root .dj-cust-no-portal {
  display: flex !important; align-items: flex-start !important;
  gap: 10px !important; padding: 14px 16px !important;
  color: #64748b !important;
}
#dj-app-root .dj-cust-no-portal svg { flex-shrink: 0 !important; color: #94a3b8 !important; margin-top: 1px !important; }


/* ============================================================
   iOS / iPhone: prevent auto-zoom on input focus
   All inputs must be >= 16px computed font-size on mobile.
   This overrides any sub-16px rules set above.
   ============================================================ */
@media (max-width: 768px) {
  #dj-app-root input,
  #dj-app-root input[type="text"],
  #dj-app-root input[type="search"],
  #dj-app-root input[type="email"],
  #dj-app-root input[type="tel"],
  #dj-app-root input[type="number"],
  #dj-app-root input[type="password"],
  #dj-app-root input[type="date"],
  #dj-app-root input[type="time"],
  #dj-app-root textarea,
  #dj-app-root select {
    font-size: 16px !important;
  }
}

/* ============================================================
   Smart Monitor Tab
============================================================ */
#dj-app-root .dj-monitor-card {
  background: #fff !important;
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 12px !important;
  padding: 18px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.07) !important;
  transition: box-shadow .2s !important;
}
#dj-app-root .dj-monitor-card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.12) !important;
}
#dj-app-root .dj-monitor-card-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
}
#dj-app-root .dj-monitor-card-name {
  font-weight: 700 !important;
  font-size: 15px !important;
  color: #0f172a !important;
  line-height: 1.3 !important;
}
#dj-app-root .dj-monitor-card-address {
  font-size: 12px !important;
  color: #64748b !important;
  margin-top: -8px !important;
}
#dj-app-root .dj-monitor-status-pill {
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 3px 9px !important;
  border-radius: 20px !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
}
#dj-app-root .dj-monitor-temps {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 4px !important;
  background: #f8fafc !important;
  border-radius: 8px !important;
  padding: 12px 8px !important;
  text-align: center !important;
}
#dj-app-root .dj-monitor-temp-val {
  font-size: 20px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
}
#dj-app-root .dj-monitor-temp-lbl {
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: #94a3b8 !important;
  margin-top: 3px !important;
}
#dj-app-root .dj-monitor-card-footer {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  font-size: 12px !important;
  color: #64748b !important;
  border-top: 1px solid #f1f5f9 !important;
  padding-top: 10px !important;
  margin-top: -4px !important;
}
@keyframes dj-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.35; }
}

/* ============================================================
   Smooth content transitions — applied by smoothHtml()
============================================================ */
#dj-app-root #dj-app-jobs-table,
#dj-app-root #dj-app-calendar,
#dj-app-root #dj-app-users-table,
#dj-app-root #dj-app-customers-table,
#dj-app-root #dj-app-track-result,
#dj-app-root #dj-monitor-grid {
  transition: opacity .22s ease !important;
}
