:root {
  --background: oklch(0.9892 0.0054 117.9205);
  --foreground: oklch(0.2077 0.0398 265.7549);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.2077 0.0398 265.7549);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.2077 0.0398 265.7549);
  --primary: oklch(0.8871 0.2122 128.5041);
  --primary-foreground: oklch(0 0 0);
  --secondary: oklch(0.3717 0.0392 257.287);
  --secondary-foreground: oklch(0.9842 0.0034 247.8575);
  --muted: oklch(0.9683 0.0069 247.8956);
  --muted-foreground: oklch(0.5544 0.0407 257.4166);
  --accent: oklch(0.9819 0.0181 155.8263);
  --accent-foreground: oklch(0.4479 0.1083 151.3277);
  --destructive: oklch(0.6368 0.2078 25.3313);
  --destructive-foreground: oklch(1 0 0);
  --border: oklch(0.9288 0.0126 255.5078);
  --input: oklch(0.9288 0.0126 255.5078);
  --ring: oklch(0.8871 0.2122 128.5041);
  --chart-1: oklch(0.8871 0.2122 128.5041);
  --chart-2: oklch(0.3717 0.0392 257.287);
  --chart-3: oklch(0.7227 0.192 149.5793);
  --chart-4: oklch(0.5544 0.0407 257.4166);
  --chart-5: oklch(0.7107 0.0351 256.7878);
  --sidebar: oklch(1 0 0);
  --sidebar-foreground: oklch(0.2077 0.0398 265.7549);
  --sidebar-primary: oklch(0.8871 0.2122 128.5041);
  --sidebar-primary-foreground: oklch(0 0 0);
  --sidebar-accent: oklch(0.9842 0.0034 247.8575);
  --sidebar-accent-foreground: oklch(0.2077 0.0398 265.7549);
  --sidebar-border: oklch(0.9683 0.0069 247.8956);
  --sidebar-ring: oklch(0.8871 0.2122 128.5041);
  --font-sans: Inter, system-ui, sans-serif;
  --font-serif: Georgia, serif;
  --font-mono: JetBrains Mono, monospace;
  --radius: 1rem;
  --shadow-sm: 0 8px 20px 0 hsl(0 0% 0% / 0.05), 0 1px 2px -1px hsl(0 0% 0% / 0.05);
  --shadow: 0 8px 20px 0 hsl(0 0% 0% / 0.05), 0 1px 2px -1px hsl(0 0% 0% / 0.05);
  --shadow-md: 0 8px 20px 0 hsl(0 0% 0% / 0.05), 0 2px 4px -1px hsl(0 0% 0% / 0.05);
  --shadow-lg: 0 8px 20px 0 hsl(0 0% 0% / 0.05), 0 4px 6px -1px hsl(0 0% 0% / 0.05);
  --tracking-normal: -0.01em;
}

.dark {
  --background: oklch(0.1288 0.0406 264.6952);
  --foreground: oklch(0.9842 0.0034 247.8575);
  --card: oklch(0.2077 0.0398 265.7549);
  --card-foreground: oklch(0.9842 0.0034 247.8575);
  --popover: oklch(0.2077 0.0398 265.7549);
  --popover-foreground: oklch(0.9842 0.0034 247.8575);
  --primary: oklch(0.8871 0.2122 128.5041);
  --primary-foreground: oklch(0 0 0);
  --secondary: oklch(0.2795 0.0368 260.031);
  --secondary-foreground: oklch(0.9842 0.0034 247.8575);
  --muted: oklch(0.2795 0.0368 260.031);
  --muted-foreground: oklch(0.7107 0.0351 256.7878);
  --accent: oklch(0.3925 0.0896 152.5353);
  --accent-foreground: oklch(0.8871 0.2122 128.5041);
  --destructive: oklch(0.4437 0.1613 26.8994);
  --destructive-foreground: oklch(1 0 0);
  --border: oklch(0.2795 0.0368 260.031);
  --input: oklch(0.2795 0.0368 260.031);
  --ring: oklch(0.8871 0.2122 128.5041);
  --sidebar: oklch(0.1288 0.0406 264.6952);
  --sidebar-foreground: oklch(0.9842 0.0034 247.8575);
  --sidebar-primary: oklch(0.8871 0.2122 128.5041);
  --sidebar-primary-foreground: oklch(0 0 0);
  --sidebar-accent: oklch(0.2795 0.0368 260.031);
  --sidebar-accent-foreground: oklch(0.9842 0.0034 247.8575);
  --sidebar-border: oklch(0.2795 0.0368 260.031);
  --sidebar-ring: oklch(0.8871 0.2122 128.5041);
  --shadow: 0 10px 25px 0 hsl(0 0% 0% / 0.4), 0 1px 2px -1px hsl(0 0% 0% / 0.4);
  --shadow-lg: 0 10px 25px 0 hsl(0 0% 0% / 0.4), 0 4px 6px -1px hsl(0 0% 0% / 0.4);
}

@media (prefers-color-scheme: dark) {
  :root {
    --background: oklch(0.1288 0.0406 264.6952);
    --foreground: oklch(0.9842 0.0034 247.8575);
    --card: oklch(0.2077 0.0398 265.7549);
    --card-foreground: oklch(0.9842 0.0034 247.8575);
    --border: oklch(0.2795 0.0368 260.031);
    --input: oklch(0.2795 0.0368 260.031);
    --muted: oklch(0.2795 0.0368 260.031);
    --muted-foreground: oklch(0.7107 0.0351 256.7878);
    --shadow: 0 10px 25px 0 hsl(0 0% 0% / 0.4), 0 1px 2px -1px hsl(0 0% 0% / 0.4);
  }
}

* {
  border-color: var(--border);
  outline-color: color-mix(in oklab, var(--ring), transparent 50%);
}

html, body {
  background: var(--background) !important;
  color: var(--foreground) !important;
  font-family: var(--font-sans);
  letter-spacing: var(--tracking-normal);
}

.container-fluid {
  background: var(--background);
  color: var(--foreground);
}

/* ─── Cards ───────────────────────────────────────────────────────────────── */

.card,
.Select-control {
  background: var(--card) !important;
  color: var(--card-foreground) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm);
}

.card h1, .card h2, .card h3, .card h4, .card h5, .card h6,
.card p, .card span, .card label {
  color: var(--card-foreground) !important;
}

/* ─── Inputs — UNIFIED (fixes white background issue) ─────────────────────── */

.form-control,
.form-select,
.DateInput_input,
.input-custom,
.input-custom.form-control,
.input-custom.form-select {
  background: var(--card) !important;
  color: var(--card-foreground) !important;
  border: 1px solid var(--border) !important;
  border-radius: calc(var(--radius) * 0.75) !important;
  box-shadow: none !important;
  font-family: var(--font-sans) !important;
  font-size: 0.875rem !important;
  padding: 0.5rem 0.75rem !important;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.form-control:focus,
.form-select:focus,
.input-custom:focus {
  border-color: var(--ring) !important;
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--ring) 25%, transparent) !important;
  outline: none !important;
}

.form-control::placeholder,
.input-custom::placeholder {
  color: var(--muted-foreground) !important;
  opacity: 0.6;
}

/* ─── Buttons ─────────────────────────────────────────────────────────────── */

.btn-primary {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--primary-foreground) !important;
  font-weight: 600;
  border-radius: calc(var(--radius) * 0.75) !important;
  transition: filter 0.15s ease, box-shadow 0.15s ease;
}

.btn-primary:hover {
  filter: brightness(1.05);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 20%, transparent) !important;
}

.btn-secondary {
  background: var(--secondary) !important;
  border-color: var(--secondary) !important;
  color: var(--secondary-foreground) !important;
  font-weight: 500;
  border-radius: calc(var(--radius) * 0.75) !important;
  transition: filter 0.15s ease;
}

.btn-secondary:hover {
  filter: brightness(1.15);
}

.btn-danger {
  background: var(--destructive) !important;
  border-color: var(--destructive) !important;
  color: var(--destructive-foreground) !important;
  font-weight: 500;
  border-radius: calc(var(--radius) * 0.75) !important;
}

.btn-outline-secondary {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  color: var(--muted-foreground) !important;
  font-weight: 500;
  border-radius: calc(var(--radius) * 0.75) !important;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.btn-outline-secondary:hover {
  background: var(--muted) !important;
  color: var(--foreground) !important;
  border-color: var(--border) !important;
}

.nav-tabs .nav-link.active {
  background: var(--accent) !important;
  color: var(--accent-foreground) !important;
  border-color: var(--border) !important;
}

.nav-tabs .nav-link {
  color: var(--muted-foreground) !important;
}

/* ─── DataTable ───────────────────────────────────────────────────────────── */

.dash-table-container {
  font-family: var(--font-sans);
  margin: 0.5rem 0 1.25rem;
}

.dash-table-container .dash-spreadsheet,
.dash-table-container .dash-spreadsheet-container,
.dash-table-container .dash-spreadsheet-inner,
.dash-table-container .dash-spreadsheet-inner td,
.dash-table-container .dash-spreadsheet-inner th,
.dash-table-container .dash-spreadsheet-inner div,
.dash-table-container .previous-next-container,
.dash-table-container .previous-next-container button {
  font-family: var(--font-sans) !important;
}

.dash-table-container .dash-spreadsheet-container {
  background: var(--card) !important;
  color: var(--card-foreground) !important;
  border: 1px solid var(--border) !important;
  border-radius: calc(var(--radius) * 0.75) !important;
  box-shadow: none !important;
  overflow: hidden;
}

/* Override dash-table bundled default (white) on data cells */
.dash-table-container .dash-spreadsheet-container .dash-spreadsheet-inner td {
  background-color: var(--card) !important;
  color: var(--card-foreground) !important;
}

/* Row selection column — dash-table hardcodes 30px inline on .dash-select-cell */
.dash-table-container .dash-select-cell {
  min-width: 50px !important;
  max-width: 50px !important;
  width: 50px !important;
}

.dash-table-container .dash-header {
  background: #020617 !important;
  color: #f8fafc !important;
  font-weight: 500 !important;
  font-size: 0.875rem !important;
  border: none !important;
  border-bottom: 1px solid var(--border) !important;
}

.dash-table-container .dash-header .column-header-name {
  color: #f8fafc !important;
}

/* Force header style across all DataTable internal structures */
.dash-table-container .dash-spreadsheet-container th,
.dash-table-container .dash-spreadsheet-container thead th,
.dash-table-container .dash-spreadsheet-inner th,
.dash-table-container .dash-spreadsheet-inner tr th,
.dash-table-container .dash-spreadsheet-inner tr:first-child th,
.dash-table-container .dash-spreadsheet-inner tr:first-child td {
  background: #020617 !important;
  color: #f8fafc !important;
}

.dash-table-container .dash-spreadsheet-container th .column-header-name,
.dash-table-container .dash-spreadsheet-container th .column-actions span,
.dash-table-container .dash-spreadsheet-container th .column-header--sort,
.dash-table-container .dash-spreadsheet-container th svg {
  color: #f8fafc !important;
  fill: #f8fafc !important;
}

.dash-table-container .dash-cell {
  background: var(--card) !important;
  color: var(--card-foreground) !important;
  border: none !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 0.75rem 1rem !important;
  font-size: 0.875rem !important;
  line-height: 1.35 !important;
  vertical-align: top !important;
  overflow: hidden !important;
}

/* Limit cell content to 2 lines with ellipsis */
.dash-table-container .dash-cell .dash-cell-value,
.dash-table-container .dash-cell > div:not(.column-actions) {
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: normal !important;
  word-break: break-word !important;
  line-height: 1.35 !important;
  max-height: calc(1.35em * 2) !important;
}

.dash-cell-custom-tooltip {
  position: fixed;
  z-index: 10000;
  display: none;
  max-width: min(28rem, calc(100vw - 1.5rem));
  padding: 0.5rem 0.75rem;
  background: #020617;
  color: #f8fafc;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) * 0.5);
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  line-height: 1.4;
  white-space: pre-wrap;
  word-break: break-word;
  box-shadow: var(--shadow-lg);
  pointer-events: none;
}

.dash-table-container .dash-cell.focused {
  background: color-mix(in oklab, var(--muted) 25%, var(--card)) !important;
}

.dash-table-container .dash-filter {
  background: var(--card) !important;
  color: var(--card-foreground) !important;
  border-color: var(--border) !important;
}

.dash-table-container .dash-spreadsheet-inner tr:last-child .dash-cell {
  border-bottom: none !important;
}

.dash-table-container .previous-next-container {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  padding: 0.875rem 1rem;
  margin: 0;
  border-top: 1px solid var(--border);
  background: var(--card) !important;
  color: var(--muted-foreground) !important;
  font-size: 0.875rem;
  line-height: 1.5;
}

.dash-table-container .previous-next-container .page-number,
.dash-table-container .previous-next-container .page-number .current-page-container,
.dash-table-container .previous-next-container .page-number .current-page-container input.current-page {
  color: var(--muted-foreground) !important;
  font-size: 0.875rem !important;
  font-weight: 400 !important;
  min-width: auto !important;
  background: transparent !important;
  border: none !important;
}

.dash-table-container .previous-next-container button.first-page,
.dash-table-container .previous-next-container button.last-page,
.dash-table-container .previous-next-container button.previous-page,
.dash-table-container .previous-next-container button.next-page {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  min-width: 2rem !important;
  padding: 0 !important;
  margin: 0 0.125rem !important;
  border-radius: 9999px !important;
  border: 1px solid var(--border) !important;
  background: var(--card) !important;
  color: var(--muted-foreground) !important;
  font-size: 0.75rem !important;
  line-height: 1 !important;
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.dash-table-container .previous-next-container button.first-page:hover:not(:disabled),
.dash-table-container .previous-next-container button.last-page:hover:not(:disabled),
.dash-table-container .previous-next-container button.previous-page:hover:not(:disabled),
.dash-table-container .previous-next-container button.next-page:hover:not(:disabled) {
  background: var(--muted) !important;
  color: var(--foreground) !important;
  border-color: var(--border) !important;
}

.dash-table-container .previous-next-container button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.dash-table-container input:not([type="checkbox"]):not([type="radio"]),
.dash-table-container select {
  background: var(--background) !important;
  color: var(--foreground) !important;
  border: 1px solid var(--border) !important;
  border-radius: calc(var(--radius) * 0.5) !important;
}

/* ─── Dashboard Layout ────────────────────────────────────────────────────── */

.dashboard-root {
  max-width: 100%;
  padding: 0;
}

.dashboard-shell {
  display: flex;
  min-height: 100vh;
  gap: 0;
}

.dashboard-sidebar {
  flex: 0 0 16rem;
  width: 16rem;
  min-height: 100%;
  background: var(--sidebar);
  color: var(--sidebar-foreground);
  border-right: 1px solid var(--sidebar-border);
  padding: 1.25rem 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0 0.5rem;
  font-weight: 600;
  font-size: 0.95rem;
}

.sidebar-brand-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: calc(var(--radius) * 0.5);
  background: var(--sidebar-primary);
  color: var(--sidebar-primary-foreground);
  font-size: 0.875rem;
  font-weight: 700;
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.sidebar-nav-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid transparent;
  border-radius: calc(var(--radius) * 0.75);
  background: transparent;
  color: var(--sidebar-foreground);
  font-size: 0.875rem;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.sidebar-nav-item .nav-icon {
  font-size: 1rem;
  line-height: 1;
}

.sidebar-nav-item:hover {
  background: var(--sidebar-accent);
  color: var(--sidebar-accent-foreground);
}

.sidebar-nav-item.active {
  background: var(--sidebar-accent);
  color: var(--sidebar-accent-foreground);
  border-color: var(--sidebar-border);
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--sidebar-primary) 25%, transparent);
}

.dashboard-main {
  flex: 1;
  min-width: 0;
  padding: 1.25rem 1.5rem;
  overflow-x: auto;
}

/* ─── Page Header (contextual per tab) ────────────────────────────────────── */

.page-header {
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border);
}

.page-header-title {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 0.25rem;
  color: var(--foreground) !important;
}

.page-header-subtitle {
  font-size: 0.875rem;
  color: var(--muted-foreground) !important;
  margin: 0;
}

/* ─── Login Screen ────────────────────────────────────────────────────────── */

.login-screen {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: var(--background);
}

.login-card-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2rem;
  width: 100%;
  max-width: 24rem;
  padding: 2rem 1rem;
}

.login-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  text-align: center;
}

.login-brand-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: calc(var(--radius) * 0.75);
  background: var(--primary);
  color: var(--primary-foreground);
  font-size: 1.5rem;
  font-weight: 800;
  box-shadow: 0 0 20px color-mix(in oklab, var(--primary) 30%, transparent);
}

.login-brand-text {
  font-size: 1.75rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.03em;
  color: var(--foreground) !important;
  margin: 0.25rem 0 0 !important;
}

.login-brand-subtitle {
  font-size: 0.875rem;
  color: var(--muted-foreground) !important;
  margin: 0 !important;
}

.login-card {
  width: 100%;
  padding: 0.5rem !important;
}

.login-title {
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em;
  margin-bottom: 0.25rem !important;
}

.login-subtitle-text {
  font-size: 0.8125rem !important;
  color: var(--muted-foreground) !important;
  margin-bottom: 1.25rem !important;
}

.login-submit-btn {
  width: 100%;
  padding: 0.625rem !important;
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  margin-top: 0.5rem;
}

/* ─── Form Components ─────────────────────────────────────────────────────── */

.form-group-custom {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  margin-bottom: 0.75rem;
}

.form-label-custom {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--muted-foreground) !important;
  letter-spacing: var(--tracking-normal);
}

.form-card {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  background: var(--card) !important;
}

.form-card-title {
  font-size: 1rem !important;
  font-weight: 600 !important;
  margin-bottom: 1rem !important;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--border);
}

.checklist-custom {
  display: flex;
  align-items: center;
  padding-top: 1.75rem;
}

.checklist-custom .form-check {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}

.checklist-custom .form-check-label {
  font-size: 0.8125rem;
  color: var(--card-foreground) !important;
}

/* ─── Section Titles ──────────────────────────────────────────────────────── */

.section-title {
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--foreground) !important;
  letter-spacing: -0.01em;
}

/* ─── Filter Actions ──────────────────────────────────────────────────────── */

.filter-actions {
  display: flex;
  align-items: flex-end;
  gap: 0.5rem;
  padding-bottom: 0.125rem;
}

.filter-btn {
  padding: 0.5rem 1rem !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  white-space: nowrap;
}

.system-status-text {
  font-size: 0.8125rem;
  color: var(--muted-foreground);
  display: flex;
  align-items: flex-end;
  padding-bottom: 0.25rem;
}

/* ─── Metric Cards ────────────────────────────────────────────────────────── */

.metric-card {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  background: var(--card) !important;
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.metric-card:hover {
  box-shadow: var(--shadow-md);
  border-color: color-mix(in oklab, var(--primary) 30%, var(--border));
}

.metric-header {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  margin-bottom: 0.25rem;
}

.metric-icon {
  font-size: 1rem;
  line-height: 1;
}

.metric-title {
  font-size: 0.8125rem !important;
  font-weight: 500 !important;
  color: var(--muted-foreground) !important;
  margin: 0 !important;
}

.metric-value {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--foreground) !important;
  margin: 0 !important;
  letter-spacing: -0.02em;
}

.metric-row {
  gap: 0;
}

/* ─── Chart Containers ────────────────────────────────────────────────────── */

.chart-container {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.5rem;
  margin-bottom: 1rem;
}

/* ─── Date Filter Row ─────────────────────────────────────────────────────── */

.date-filter-row {
  align-items: flex-end;
}

.date-filter-field {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.date-filter-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--muted-foreground);
  letter-spacing: var(--tracking-normal);
}

.date-filter-input .SingleDatePicker,
.date-filter-input .SingleDatePickerInput {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: calc(var(--radius) * 0.75) !important;
  box-shadow: none !important;
  overflow: hidden;
}

.date-filter-input .SingleDatePickerInput {
  display: flex;
  align-items: center;
  width: 100%;
  height: 2.5rem;
  padding: 0 0.75rem;
}

.date-filter-input .DateInput {
  background: transparent !important;
  width: 100%;
}

.date-filter-input .DateInput_input {
  background: transparent !important;
  color: var(--card-foreground) !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-family: var(--font-sans) !important;
  font-size: 0.875rem !important;
  font-weight: 400;
  padding: 0 !important;
  height: auto;
  line-height: 1.5;
}

.date-filter-input .DateInput_input::placeholder {
  color: var(--muted-foreground) !important;
}

.date-filter-input .DateInput_fang {
  display: none;
}

.date-filter-input .SingleDatePicker_picker {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-lg) !important;
  color: var(--card-foreground) !important;
}

.date-filter-input .CalendarMonth,
.date-filter-input .CalendarMonth_table,
.date-filter-input .CalendarDay {
  background: var(--card) !important;
  color: var(--card-foreground) !important;
}

.date-filter-input .CalendarDay__default:hover {
  background: var(--muted) !important;
  color: var(--foreground) !important;
  border-color: var(--border) !important;
}

.date-filter-input .CalendarDay__selected,
.date-filter-input .CalendarDay__selected:active,
.date-filter-input .CalendarDay__selected:hover {
  background: var(--primary) !important;
  color: var(--primary-foreground) !important;
  border-color: var(--primary) !important;
}

.date-filter-input .CalendarMonth_caption {
  color: var(--card-foreground) !important;
}

.date-filter-input .DayPickerNavigation_button {
  background: var(--muted) !important;
  border-color: var(--border) !important;
  color: var(--card-foreground) !important;
}

.date-filter-input .DayPicker_weekHeader {
  color: var(--muted-foreground) !important;
}

.date-filter-input .CalendarDay__blocked_out_of_range,
.date-filter-input .CalendarDay__blocked_out_of_range:active,
.date-filter-input .CalendarDay__blocked_out_of_range:hover {
  color: var(--muted-foreground) !important;
  background: var(--card) !important;
  border-color: var(--border) !important;
}

/* ─── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .dashboard-shell {
    flex-direction: column;
  }

  .dashboard-sidebar {
    flex: none;
    width: 100%;
    min-height: auto;
    border-right: none;
    border-bottom: 1px solid var(--sidebar-border);
  }

  .sidebar-nav {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .sidebar-nav-item {
    width: auto;
  }

  .login-card-wrapper {
    padding: 1rem;
    max-width: 100%;
  }
}

/* Custom radio buttons in dash-table selection column */
.dash-table-container input[type="radio"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  background-color: var(--card) !important;
  border: 2px solid var(--border) !important;
  width: 1.15rem !important;
  height: 1.15rem !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  vertical-align: middle !important;
  outline: none !important;
  transition: border-color 0.15s ease, background-color 0.15s ease !important;
}

.dash-table-container input[type="radio"]:checked {
  border-color: var(--primary) !important;
  background-color: var(--primary) !important;
}

.dash-table-container input[type="radio"]:checked::after {
  content: "" !important;
  width: 0.5rem !important;
  height: 0.5rem !important;
  border-radius: 50% !important;
  background: var(--primary-foreground) !important;
  display: block !important;
}

.dash-table-container input[type="radio"]:focus {
  border-color: var(--ring) !important;
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--ring) 25%, transparent) !important;
}

/* Invert calendar picker indicator for native date inputs in dark mode */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(0.8);
  cursor: pointer;
}

/* Custom inline checkboxes styling */
.checklist-custom-inline {
  display: flex;
  align-items: center;
}

.checklist-custom-inline .form-check {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  margin-bottom: 0;
  margin-right: 1.25rem;
}

.checklist-custom-inline .form-check-label {
  font-size: 0.8125rem;
  color: var(--card-foreground) !important;
  user-select: none;
}

.user-save-msg-text {
  font-size: 0.875rem;
  color: var(--muted-foreground);
  padding-left: 0.5rem;
}
