/* ── 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-filter-row { display: flex !important; gap: 8px !important; flex-wrap: wrap !important; margin-bottom: 10px !important; }
#dj-app-root .dj-app-select {
  padding: 8px 12px !important; border: 1.5px solid #e2e8f0 !important;
  border-radius: 6px !important; font-size: 13px !important; color: #0f172a !important;
  background: #fff !important; cursor: pointer !important; outline: none !important;
}
#dj-app-root .dj-app-select: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;
  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: 34px !important; height: 34px !important; border-radius: 50% !important;
  background: #f8fafc !important; border: none !important; cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  color: #475569 !important; transition: all .15s !important;
}
#dj-app-root .dj-app-drawer-close:hover { background: #e2e8f0 !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; }
/* 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: 6px 12px !important; font-size: 12px !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; 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: 40px !important; height: 40px !important;
  background: #0f172a !important; border: none !important; border-radius: 8px !important;
  color: #fff !important; align-items: center !important; justify-content: center !important;
  cursor: pointer !important; box-shadow: 0 2px 8px rgba(0,0,0,.3) !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; }
  #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; }
