:root {
  --c-primary: #2563eb;
  --c-primary-dim: #1d4ed8;
  --c-primary-soft: #eff6ff;
  --c-primary-border: #bfdbfe;
  --c-ink-900: #0f172a;
  --c-ink-700: #1e293b;
  --c-ink-500: #475569;
  --c-ink-400: #64748b;
  --c-ink-200: #cbd5e1;
  --c-ink-100: #e2e8f0;
  --c-ink-50: #f1f5f9;
  --c-page: #f0f3f7;
  --c-card: #ffffff;
  --c-ok: #059669;
  --c-ok-soft: #d1fae5;
  --c-ok-border: #6ee7b7;
  --c-neg: #dc2626;
  --c-neg-soft: #fee2e2;
  --c-neg-border: #fca5a5;
  --c-warn: #d97706;
  --c-warn-soft: #fef3c7;
  --c-warn-border: #fde68a;
  --sidebar-w: 220px;
  --radius-card: 10px;
  --radius-sm: 6px;
  --font-body: "IBM Plex Sans", "Segoe UI", sans-serif;
  --font-display: "Space Grotesk", "IBM Plex Sans", sans-serif;
  --bs-body-font-family: "IBM Plex Sans", "Segoe UI", sans-serif;
  /* Spacing scale */
  --sp-1: 4px; --sp-2: 8px; --sp-3: 12px; --sp-4: 16px; --sp-5: 20px; --sp-6: 24px;
  /* Sidebar semantic tokens */
  --c-sidebar-bg-start: #0f172a;
  --c-sidebar-bg-end: #1e3a5f;
  --c-avatar-gradient-start: #3b82f6;
  --c-avatar-gradient-end: #6366f1;
  /* Focus ring */
  --focus-ring: 0 0 0 2px rgba(37, 99, 235, .25);
}

/* ═══════════════════════════════════════════════════════════
   DARK THEME  (body.darkmode--activated)
   ═══════════════════════════════════════════════════════════ */

/* 1. Design-token overrides + Bootstrap 5 CSS-variable overrides */
body.darkmode--activated {
  /* Project tokens */
  --c-page:           #0d1117;
  --c-card:           #161b22;
  --c-ink-900:        #f0f6fc;
  --c-ink-700:        #cdd9e5;
  --c-ink-500:        #8d96a0;
  --c-ink-400:        #6e7681;
  --c-ink-200:        #30363d;
  --c-ink-100:        #21262d;
  --c-ink-50:         #1c2128;
  --c-primary:        #58a6ff;
  --c-primary-dim:    #388bfd;
  --c-primary-soft:   #1f2d3d;
  --c-primary-border: #1f6feb;
  --c-ok:             #3fb950;
  --c-ok-soft:        #1b2e24;
  --c-ok-border:      #2ea043;
  --c-neg:            #f85149;
  --c-neg-soft:       #2d1316;
  --c-neg-border:     #da3633;
  --c-warn:           #d29922;
  --c-warn-soft:      #2e2009;
  --c-warn-border:    #9e6a03;
  --focus-ring:       0 0 0 2px rgba(88, 166, 255, .3);

  /* Bootstrap 5 tokens — overriding the library's own variables so its
     components pick up dark colors without extra selectors */
  --bs-body-bg:                   #0d1117;
  --bs-body-color:                #cdd9e5;
  --bs-secondary-bg:              #1c2128;
  --bs-tertiary-bg:               #21262d;
  --bs-border-color:              #30363d;
  --bs-border-color-translucent:  rgba(255,255,255,.1);
  --bs-link-color:                #58a6ff;
  --bs-link-hover-color:          #79c0ff;
  --bs-emphasis-color:            #f0f6fc;
  --bs-heading-color:             #f0f6fc;

  /* Card */
  --bs-card-bg:                   #161b22;
  --bs-card-border-color:         #30363d;
  --bs-card-cap-bg:               #1c2128;

  /* Table */
  --bs-table-bg:                  transparent;
  --bs-table-color:               #cdd9e5;
  --bs-table-border-color:        #30363d;
  --bs-table-striped-bg:          rgba(255,255,255,.03);
  --bs-table-hover-bg:            rgba(255,255,255,.05);
  --bs-table-active-bg:           rgba(255,255,255,.07);

  /* Dropdown */
  --bs-dropdown-bg:               #1c2128;
  --bs-dropdown-border-color:     #30363d;
  --bs-dropdown-link-color:       #cdd9e5;
  --bs-dropdown-link-hover-bg:    #21262d;
  --bs-dropdown-link-hover-color: #f0f6fc;
  --bs-dropdown-link-active-bg:   #1f6feb;
  --bs-dropdown-divider-bg:       #30363d;
  --bs-dropdown-header-color:     #8d96a0;

  /* Form */
  --bs-form-control-bg:           #1c2128;
  --bs-form-control-border-color: #30363d;
  --bs-input-bg:                  #1c2128;
  --bs-input-border-color:        #30363d;
  --bs-input-color:               #cdd9e5;
  --bs-input-placeholder-color:   #6e7681;
  --bs-input-group-addon-bg:      #21262d;
  --bs-input-group-addon-border-color: #30363d;
  --bs-input-group-addon-color:   #8d96a0;

  /* Modal */
  --bs-modal-bg:                  #161b22;
  --bs-modal-border-color:        #30363d;
  --bs-modal-header-border-color: #30363d;
  --bs-modal-footer-border-color: #30363d;
  --bs-modal-content-bg:          #161b22;

  /* Nav / Tabs */
  --bs-nav-tabs-border-color:        #30363d;
  --bs-nav-tabs-link-hover-border-color: #30363d;
  --bs-nav-tabs-link-active-bg:      #161b22;
  --bs-nav-tabs-link-active-border-color: #30363d;
  --bs-nav-tabs-link-active-color:   #f0f6fc;

  /* Pagination */
  --bs-pagination-bg:             #161b22;
  --bs-pagination-border-color:   #30363d;
  --bs-pagination-color:          #58a6ff;
  --bs-pagination-hover-bg:       #1c2128;
  --bs-pagination-hover-border-color: #30363d;
  --bs-pagination-hover-color:    #79c0ff;
  --bs-pagination-active-bg:      #1f6feb;
  --bs-pagination-active-border-color: #1f6feb;
  --bs-pagination-disabled-bg:    #161b22;
  --bs-pagination-disabled-color: #6e7681;
  --bs-pagination-disabled-border-color: #30363d;

  /* List group */
  --bs-list-group-bg:             #161b22;
  --bs-list-group-border-color:   #30363d;
  --bs-list-group-color:          #cdd9e5;
  --bs-list-group-hover-bg:       #1c2128;
  --bs-list-group-action-hover-bg:  #1c2128;
  --bs-list-group-action-hover-color: #f0f6fc;
  --bs-list-group-active-bg:      #1f6feb;
  --bs-list-group-active-border-color: #1f6feb;

  /* Accordion */
  --bs-accordion-bg:              #161b22;
  --bs-accordion-border-color:    #30363d;
  --bs-accordion-btn-bg:          #1c2128;
  --bs-accordion-btn-color:       #cdd9e5;
  --bs-accordion-active-bg:       #1f2d3d;
  --bs-accordion-active-color:    #58a6ff;
  --bs-accordion-body-bg:         #161b22;

  /* Tooltip / Popover */
  --bs-tooltip-bg:                #30363d;
  --bs-tooltip-color:             #f0f6fc;
  --bs-popover-bg:                #1c2128;
  --bs-popover-border-color:      #30363d;
  --bs-popover-header-bg:         #21262d;

  /* Offcanvas */
  --bs-offcanvas-bg:              #161b22;
  --bs-offcanvas-border-color:    #30363d;
  --bs-offcanvas-color:           #cdd9e5;

  /* Progress */
  --bs-progress-bg:               #21262d;

  /* Close button */
  --bs-btn-close-filter:          invert(1) grayscale(100%) brightness(200%);
}

/* 2. Bootstrap table rows — need explicit bg since BS sets them on cells */
body.darkmode--activated .table > :not(caption) > * > * {
  background-color: var(--c-card);
  color: var(--c-ink-700);
  border-bottom-color: var(--c-ink-100);
}
body.darkmode--activated .table > thead > * > * {
  background-color: var(--c-ink-50) !important;
  color: var(--c-ink-500);
}
body.darkmode--activated .table-hover > tbody > tr:hover > * {
  background-color: var(--c-ink-50);
  color: var(--c-ink-700);
}
body.darkmode--activated .table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: rgba(255,255,255,.03);
}

/* 3. Forms — !important beats Bootstrap's specificity */
body.darkmode--activated .form-control,
body.darkmode--activated .form-select,
body.darkmode--activated .input-group-text,
body.darkmode--activated input:not([type=checkbox]):not([type=radio]):not([type=range]),
body.darkmode--activated select,
body.darkmode--activated textarea {
  background-color: var(--c-ink-50) !important;
  color: var(--c-ink-900) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .form-control:focus,
body.darkmode--activated .form-select:focus,
body.darkmode--activated input:focus,
body.darkmode--activated select:focus,
body.darkmode--activated textarea:focus {
  background-color: var(--c-ink-50) !important;
  color: var(--c-ink-900) !important;
  border-color: var(--c-primary) !important;
  box-shadow: var(--focus-ring) !important;
}
body.darkmode--activated .form-control::placeholder,
body.darkmode--activated input::placeholder,
body.darkmode--activated textarea::placeholder { color: var(--c-ink-400) !important; }
body.darkmode--activated .form-check-input {
  background-color: var(--c-ink-50);
  border-color: var(--c-ink-200);
}
body.darkmode--activated .form-check-input:checked {
  background-color: var(--c-primary);
  border-color: var(--c-primary);
}
body.darkmode--activated .form-label,
body.darkmode--activated label { color: var(--c-ink-700); }

/* 4. Buttons */
body.darkmode--activated .btn-primary {
  background-color: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
  color: #fff !important;
}
body.darkmode--activated .btn-primary:hover {
  background-color: var(--c-primary-dim) !important;
  border-color: var(--c-primary-dim) !important;
}
body.darkmode--activated .btn-secondary {
  background-color: var(--c-ink-100) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .btn-secondary:hover {
  background-color: var(--c-ink-200) !important;
}
body.darkmode--activated .btn-danger {
  background-color: var(--c-neg) !important;
  border-color: var(--c-neg-border) !important;
}
body.darkmode--activated .btn-success {
  background-color: var(--c-ok) !important;
  border-color: var(--c-ok-border) !important;
}
body.darkmode--activated .btn-warning {
  background-color: var(--c-warn) !important;
  border-color: var(--c-warn-border) !important;
  color: #0d1117 !important;
}
body.darkmode--activated .btn-light {
  background-color: var(--c-ink-100) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .btn-dark {
  background-color: var(--c-ink-50) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-900) !important;
}
body.darkmode--activated .btn-outline-primary {
  color: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
}
body.darkmode--activated .btn-outline-primary:hover {
  background-color: var(--c-primary-soft) !important;
}
body.darkmode--activated .btn-outline-secondary {
  color: var(--c-ink-700) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .btn-outline-secondary:hover {
  background-color: var(--c-ink-50) !important;
}
body.darkmode--activated .btn-outline-danger {
  color: var(--c-neg) !important;
  border-color: var(--c-neg) !important;
}
body.darkmode--activated .btn-outline-danger:hover {
  background-color: var(--c-neg-soft) !important;
}
body.darkmode--activated .btn-ghost {
  color: var(--c-ink-700);
  border-color: var(--c-ink-200);
  background: transparent;
}
body.darkmode--activated .btn-ghost:hover { background: var(--c-ink-50); color: var(--c-ink-900); }
body.darkmode--activated .btn-outline {
  border-color: var(--c-ink-200);
  color: var(--c-ink-700);
  background: transparent;
}
body.darkmode--activated .btn-outline:hover { background: var(--c-ink-50); }

/* 5. Dropdown */
body.darkmode--activated .dropdown-menu {
  background-color: var(--c-ink-50) !important;
  border-color: var(--c-ink-200) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.4) !important;
}
body.darkmode--activated .dropdown-item {
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .dropdown-item:hover,
body.darkmode--activated .dropdown-item:focus {
  background-color: var(--c-ink-100) !important;
  color: var(--c-ink-900) !important;
}
body.darkmode--activated .dropdown-item.active,
body.darkmode--activated .dropdown-item:active {
  background-color: var(--c-primary-soft) !important;
  color: var(--c-primary) !important;
}
body.darkmode--activated .dropdown-divider { border-color: var(--c-ink-200) !important; }
body.darkmode--activated .dropdown-header { color: var(--c-ink-500) !important; }

/* 6. Cards */
body.darkmode--activated .card {
  background-color: var(--c-card) !important;
  border-color: var(--c-ink-100) !important;
}
body.darkmode--activated .card-header,
body.darkmode--activated .card-footer {
  background-color: var(--c-ink-50) !important;
  border-color: var(--c-ink-100) !important;
  color: var(--c-ink-700);
}
body.darkmode--activated .card-body { color: var(--c-ink-700); }

/* 7. Modals */
body.darkmode--activated .modal-content {
  background-color: var(--c-card) !important;
  border-color: var(--c-ink-100) !important;
  color: var(--c-ink-700);
}
body.darkmode--activated .modal-header,
body.darkmode--activated .modal-footer {
  border-color: var(--c-ink-100) !important;
}
body.darkmode--activated .modal-title { color: var(--c-ink-900); }
body.darkmode--activated .modal-backdrop { background-color: #000 !important; }
body.darkmode--activated .modal-box { background: var(--c-card); border-color: var(--c-ink-100); }

/* 8. Alerts */
body.darkmode--activated .alert-primary   { background: var(--c-primary-soft); border-color: var(--c-primary-border); color: var(--c-ink-700); }
body.darkmode--activated .alert-info      { background: var(--c-primary-soft); border-color: var(--c-primary-border); color: var(--c-ink-700); }
body.darkmode--activated .alert-success   { background: var(--c-ok-soft);      border-color: var(--c-ok-border);      color: var(--c-ink-700); }
body.darkmode--activated .alert-danger    { background: var(--c-neg-soft);     border-color: var(--c-neg-border);     color: var(--c-ink-700); }
body.darkmode--activated .alert-warning   { background: var(--c-warn-soft);    border-color: var(--c-warn-border);    color: var(--c-ink-700); }
body.darkmode--activated .alert-secondary { background: var(--c-ink-50);       border-color: var(--c-ink-200);        color: var(--c-ink-700); }

/* 9. Badges (Bootstrap) */
body.darkmode--activated .badge.bg-primary   { background-color: var(--c-primary) !important; }
body.darkmode--activated .badge.bg-secondary { background-color: var(--c-ink-200) !important; color: var(--c-ink-700) !important; }
body.darkmode--activated .badge.bg-success   { background-color: var(--c-ok) !important; }
body.darkmode--activated .badge.bg-danger    { background-color: var(--c-neg) !important; }
body.darkmode--activated .badge.bg-warning   { background-color: var(--c-warn) !important; color: #0d1117 !important; }
body.darkmode--activated .badge.bg-light     { background-color: var(--c-ink-100) !important; color: var(--c-ink-700) !important; }

/* 10. Nav tabs / pills */
body.darkmode--activated .nav-tabs { border-color: var(--c-ink-200); }
body.darkmode--activated .nav-tabs .nav-link {
  color: var(--c-ink-500);
  border-color: transparent;
}
body.darkmode--activated .nav-tabs .nav-link:hover {
  border-color: var(--c-ink-200);
  color: var(--c-ink-700);
}
body.darkmode--activated .nav-tabs .nav-link.active {
  background-color: var(--c-card);
  border-color: var(--c-ink-200) var(--c-ink-200) var(--c-card);
  color: var(--c-ink-900);
}
body.darkmode--activated .nav-pills .nav-link { color: var(--c-ink-500); }
body.darkmode--activated .nav-pills .nav-link.active {
  background-color: var(--c-primary-soft);
  color: var(--c-primary);
}

/* 11. List group */
body.darkmode--activated .list-group-item {
  background-color: var(--c-card) !important;
  border-color: var(--c-ink-100) !important;
  color: var(--c-ink-700);
}
body.darkmode--activated .list-group-item:hover,
body.darkmode--activated .list-group-item-action:hover {
  background-color: var(--c-ink-50) !important;
  color: var(--c-ink-900);
}

/* 12. Pagination */
body.darkmode--activated .page-link {
  background-color: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-primary) !important;
}
body.darkmode--activated .page-link:hover {
  background-color: var(--c-ink-50) !important;
}
body.darkmode--activated .page-item.active .page-link {
  background-color: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
  color: #fff !important;
}
body.darkmode--activated .page-item.disabled .page-link {
  background-color: var(--c-card) !important;
  color: var(--c-ink-400) !important;
}

/* 13. Accordion */
body.darkmode--activated .accordion-item {
  background-color: var(--c-card) !important;
  border-color: var(--c-ink-100) !important;
}
body.darkmode--activated .accordion-button {
  background-color: var(--c-ink-50) !important;
  color: var(--c-ink-900) !important;
  box-shadow: inset 0 -1px 0 var(--c-ink-100);
}
body.darkmode--activated .accordion-button::after { filter: invert(1); }
body.darkmode--activated .accordion-button:not(.collapsed) {
  background-color: var(--c-primary-soft) !important;
  color: var(--c-primary) !important;
}
body.darkmode--activated .accordion-body { color: var(--c-ink-700); }

/* 14. Select2 (used for tag selects) */
body.darkmode--activated .select2-container--default .select2-selection--multiple,
body.darkmode--activated .select2-container--default .select2-selection--single {
  background-color: var(--c-ink-50) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-900);
}
body.darkmode--activated .select2-dropdown {
  background-color: var(--c-ink-50) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .select2-results__option {
  color: var(--c-ink-700);
}
body.darkmode--activated .select2-results__option--highlighted {
  background-color: var(--c-primary-soft) !important;
  color: var(--c-primary) !important;
}
body.darkmode--activated .select2-search__field {
  background-color: var(--c-ink-100) !important;
  color: var(--c-ink-900) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .select2-selection__choice {
  background-color: var(--c-ink-100) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}

/* 15. Project-specific: page layout */
body.darkmode--activated .table-card,
body.darkmode--activated .page-shell   { background: var(--c-page); }
body.darkmode--activated .page-head    { border-color: var(--c-ink-100); }
body.darkmode--activated .page-title   { color: var(--c-ink-900); }
body.darkmode--activated .page-subtitle { color: var(--c-ink-500); }
body.darkmode--activated .page-breadcrumb a { color: var(--c-ink-500); }
body.darkmode--activated .section-head { border-color: var(--c-ink-100); color: var(--c-ink-900); }

/* 16. Project-specific: custom table (.t) */
body.darkmode--activated .t { border-color: var(--c-ink-100); background: var(--c-card); }
body.darkmode--activated .t thead th {
  background: var(--c-ink-50) !important;
  color: var(--c-ink-500);
  border-color: var(--c-ink-100);
}
body.darkmode--activated .t tbody td {
  background: var(--c-card);
  color: var(--c-ink-700);
  border-color: var(--c-ink-100);
}
body.darkmode--activated .t tbody tr:hover td {
  background: var(--c-ink-50) !important;
  color: var(--c-ink-900);
}

/* 17. Project-specific: filters */
body.darkmode--activated .filter-select-sm,
body.darkmode--activated .filter-select { background: var(--c-ink-50) !important; color: var(--c-ink-900) !important; border-color: var(--c-ink-200) !important; }
body.darkmode--activated .filter-panel,
body.darkmode--activated .filter-box   { background: var(--c-card); border-color: var(--c-ink-100); }
body.darkmode--activated .filter-label { color: var(--c-ink-500); }

/* 18. Project-specific: badges */
body.darkmode--activated .badge-ok     { background: var(--c-ok-soft);   color: var(--c-ok);   border-color: var(--c-ok-border); }
body.darkmode--activated .badge-neg    { background: var(--c-neg-soft);  color: var(--c-neg);  border-color: var(--c-neg-border); }
body.darkmode--activated .badge-warn   { background: var(--c-warn-soft); color: var(--c-warn); border-color: var(--c-warn-border); }
body.darkmode--activated .badge-muted  { background: var(--c-ink-50);    color: var(--c-ink-500); border-color: var(--c-ink-200); }
body.darkmode--activated .badge-neutral { background: var(--c-ink-50);   color: var(--c-ink-500); border-color: var(--c-ink-200); }

/* 19. Workbench (tagging session) — all wb-* with hardcoded #fff */
body.darkmode--activated .wb-page {
  background: var(--c-page) !important;
  --wb-bg: var(--c-page);
  --wb-panel: var(--c-card);
  --wb-ink: var(--c-ink-900);
  --wb-muted: var(--c-ink-400);
  --wb-border: var(--c-ink-200);
  --wb-primary-soft: #1e3a5f;
  --wb-shadow: 0 8px 20px rgba(0,0,0,.35);
}
body.darkmode--activated .wb-topbar   { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-topbar h1 { color: var(--c-ink-900); }
body.darkmode--activated .wb-subtitle  { color: var(--c-ink-400); }
body.darkmode--activated .wb-kpi-grid  { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-kpi       { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-kpi-label { color: var(--c-ink-400); }
body.darkmode--activated .wb-kpi-value { color: var(--c-ink-900); }
body.darkmode--activated .wb-main      { background: var(--c-card) !important; }
body.darkmode--activated .wb-center    { background: var(--c-card) !important; }
body.darkmode--activated .wb-toolbar   { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-panel     { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-message   { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-message--positive { background: #0d1f17 !important; border-left-color: #10b981 !important; }
body.darkmode--activated .wb-message--negative { background: #1e0d0d !important; border-left-color: #ef4444 !important; }
body.darkmode--activated .wb-message--neutral  { background: var(--c-ink-50) !important; border-left-color: #475569 !important; }
body.darkmode--activated .wb-message:hover     { background: var(--c-ink-50) !important; }
body.darkmode--activated .wb-message--positive:hover { background: #0f2a1e !important; }
body.darkmode--activated .wb-message--negative:hover { background: #261010 !important; }
body.darkmode--activated .wb-text    { color: var(--c-ink-900) !important; }
body.darkmode--activated .wb-meta    { color: var(--c-ink-400) !important; }
body.darkmode--activated .wb-meta-author { color: var(--c-ink-700) !important; }
body.darkmode--activated .wb-icon-btn {
  background: var(--c-ink-50) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-500) !important;
}
body.darkmode--activated .wb-icon-btn:hover { background: var(--c-ink-100) !important; color: var(--c-ink-900) !important; }
body.darkmode--activated .wb-form-control,
body.darkmode--activated .wb-form-select {
  background: var(--c-ink-100) !important;
  color: var(--c-ink-900) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .wb-page-btn {
  background: var(--c-ink-50) !important;
  color: var(--c-ink-700) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .wb-page-btn:hover:not(:disabled) { background: var(--c-ink-100) !important; }
body.darkmode--activated .wb-page-btn.is-active {
  background: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
  color: #fff !important;
}
body.darkmode--activated .wb-page-btn:disabled { color: var(--c-ink-400) !important; }
body.darkmode--activated .wb-pagination { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-filter-meta { color: var(--c-ink-400); }
body.darkmode--activated .wb-right-col  { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; }
body.darkmode--activated .wb-filter-head { color: var(--c-ink-900); border-color: var(--c-ink-100); }
body.darkmode--activated .wb-filter-section { border-color: var(--c-ink-100); }
body.darkmode--activated .wb-filter-label { color: var(--c-ink-700); }
body.darkmode--activated .wb-filter-apply { background: var(--c-primary) !important; color: #fff !important; }
body.darkmode--activated .wb-filter-reset { background: var(--c-ink-50) !important; color: var(--c-ink-700) !important; border-color: var(--c-ink-200) !important; }
body.darkmode--activated .wb-empty { background: var(--c-card) !important; border-color: var(--c-ink-100) !important; color: var(--c-ink-500); }
body.darkmode--activated .wb-mini-menu {
  background: var(--c-ink-50) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .wb-mini-item { color: var(--c-ink-700) !important; }
body.darkmode--activated .wb-mini-item:hover { background: var(--c-ink-100) !important; }
body.darkmode--activated .wb-chip-topic    { background: #1e1b4b; color: #a5b4fc; }
body.darkmode--activated .wb-chip-author   { background: #1b2e24; color: #6ee7b7; }
body.darkmode--activated .wb-chip-positive { background: #1b2e24; color: #4ade80; }
body.darkmode--activated .wb-chip-negative { background: #2d1316; color: #f87171; }
body.darkmode--activated .wb-chip-neutral  { background: #2e2009; color: #fbbf24; }
body.darkmode--activated .wb-tag-cta { background: #1f2d3d !important; border-color: #1f6feb !important; color: #58a6ff !important; }
body.darkmode--activated .wb-overlay { background: rgba(13,17,23,.8) !important; }

/* 20. Monitoring / messages list */
body.darkmode--activated .messages-summary-block { background: var(--c-card); border-color: var(--c-ink-100); }
body.darkmode--activated .messages-list-row { border-color: var(--c-ink-100); }
body.darkmode--activated .messages-list-row:hover { background: var(--c-ink-50); }
body.darkmode--activated .empty-state { background: var(--c-card); border-color: var(--c-ink-100); color: var(--c-ink-500); }

/* 21. AI Visibility report — run/source buttons */
body.darkmode--activated .run-type-btn,
body.darkmode--activated .source-btn {
  background: var(--c-ink-50) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .run-type-btn.active,
body.darkmode--activated .source-btn.active {
  background: var(--c-primary-soft) !important;
  border-color: var(--c-primary) !important;
  color: var(--c-primary) !important;
}
body.darkmode--activated .run-type-btn:hover,
body.darkmode--activated .source-btn:hover {
  background: var(--c-ink-100) !important;
  color: var(--c-ink-900) !important;
}

/* 22. Misc: close buttons, spinners, tooltips */
body.darkmode--activated .btn-close { filter: invert(1) grayscale(100%) brightness(200%); }
body.darkmode--activated .tooltip-inner { background-color: var(--c-ink-50); color: var(--c-ink-900); }
body.darkmode--activated .bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow::before { border-top-color: var(--c-ink-50); }
body.darkmode--activated .popover { background: var(--c-ink-50); border-color: var(--c-ink-200); }
body.darkmode--activated .popover-body { color: var(--c-ink-700); }
body.darkmode--activated .popover-header { background: var(--c-ink-100); border-color: var(--c-ink-200); color: var(--c-ink-900); }
body.darkmode--activated hr { border-color: var(--c-ink-100); }
body.darkmode--activated .text-muted { color: var(--c-ink-500) !important; }
body.darkmode--activated .border { border-color: var(--c-ink-200) !important; }

/* 23. LLM chip-label toggles (AI Visibility form) */
body.darkmode--activated .chip-label {
  background: var(--c-ink-100) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-400) !important;
}
body.darkmode--activated .chip-label:hover {
  background: var(--c-ink-50) !important;
  border-color: var(--c-primary) !important;
  color: var(--c-primary) !important;
}
body.darkmode--activated .chip-label.checked {
  background: #1e3a5f !important;
  border-color: var(--c-primary) !important;
  color: #58a6ff !important;
}

/* 24. action-btn (Instructions table row buttons) */
body.darkmode--activated .action-btn {
  background: var(--c-ink-100) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .action-btn:hover {
  background: var(--c-ink-50) !important;
  border-color: var(--c-primary) !important;
  color: var(--c-primary) !important;
}

/* 25. feed-empty gradient (Messages / Monitoring empty state) */
body.darkmode--activated .feed-empty {
  background-image: linear-gradient(120deg, var(--c-ink-50) 0%, #1a2a3d 50%, var(--c-ink-50) 100%) !important;
}
body.darkmode--activated .feed-empty-title { color: var(--c-ink-900) !important; }
body.darkmode--activated .feed-empty-sub   { color: var(--c-ink-400) !important; }

/* 26. messages-preset-menu dropdown */
body.darkmode--activated .messages-preset-menu {
  background: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .messages-preset-menu * { color: var(--c-ink-700) !important; }
body.darkmode--activated .messages-preset-item:hover { background: var(--c-ink-50) !important; }

/* 27. Tagging start — wizard-step, source-mode-card, dataset-catalog-item */
body.darkmode--activated .wizard-step {
  background: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .source-mode-card {
  background: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .source-mode-card:hover { background: var(--c-ink-50) !important; }
body.darkmode--activated .source-mode-card.active {
  background: #1e3a5f !important;
  border-color: var(--c-primary) !important;
}
body.darkmode--activated .dataset-catalog-item {
  background: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .dataset-catalog-item:hover { background: var(--c-ink-50) !important; }

/* 28. Mobile top bar (shown only on mobile, but fix for completeness) */
body.darkmode--activated .menu-preview-mobile-header {
  background: var(--c-card) !important;
  border-color: var(--c-ink-100) !important;
}

/* 29. AI Visibility profile-card (Quick run / Balanced / Maximum depth) */
body.darkmode--activated .profile-card {
  background: var(--c-ink-100) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .profile-card:hover {
  background: var(--c-primary-soft) !important;
  border-color: var(--c-primary-border) !important;
}
body.darkmode--activated .profile-card.selected {
  background: var(--c-primary-soft) !important;
  border-color: var(--c-primary) !important;
}

/* 30. Monitoring — system feed card ("All messages") */
body.darkmode--activated .feed-card-system {
  background: linear-gradient(145deg, #1a2540 0%, #162033 100%) !important;
  border-color: var(--c-primary-border) !important;
}
body.darkmode--activated .feed-card-add {
  background: linear-gradient(145deg, #1a2540 0%, #162033 100%) !important;
  border-color: #1f6feb !important;
}

/* 30b. Instructions — table row hover */
body.darkmode--activated .inst-table tbody tr:hover td {
  background: var(--c-ink-50) !important;
}

/* 30c. Help center cards and badges */
body.darkmode--activated .help-topic-card {
  background: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  box-shadow: 0 14px 28px rgba(0,0,0,.3) !important;
}
body.darkmode--activated .help-topic-category {
  background: #1e3a5f !important;
  color: #58a6ff !important;
}
body.darkmode--activated .help-topic-tag {
  background: #1e1b4b !important;
  color: #a5b4fc !important;
}
body.darkmode--activated .help-topic-title { color: var(--c-ink-900); }
body.darkmode--activated .help-topic-summary { color: var(--c-ink-400) !important; }
body.darkmode--activated .section-hero {
  background-image: linear-gradient(120deg, var(--c-ink-50) 0%, #1a2a3d 50%, var(--c-ink-50) 100%) !important;
  border-color: var(--c-ink-200) !important;
}

/* Help article page */
body.darkmode--activated .help-header-card {
  background-image: linear-gradient(140deg, var(--c-ink-50) 0%, var(--c-card) 100%) !important;
  border-color: var(--c-ink-200) !important;
}
body.darkmode--activated .help-category-pill {
  background: #1e3a5f !important;
  color: #58a6ff !important;
}
body.darkmode--activated .help-tag {
  background: #1e1b4b !important;
  color: #a5b4fc !important;
}
body.darkmode--activated .help-meta-item {
  background: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .help-article-card,
body.darkmode--activated .help-side-card {
  background: var(--c-card) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-700) !important;
}
body.darkmode--activated .help-article-body img {
  filter: brightness(0.82) contrast(0.95);
  border-radius: var(--radius-sm);
}

/* 31. File dropzone */
body.darkmode--activated .dropzone {
  background: var(--c-ink-100) !important;
  border-color: var(--c-ink-200) !important;
  color: var(--c-ink-400) !important;
}
body.darkmode--activated .dropzone:hover,
body.darkmode--activated .dropzone.dragover {
  background: var(--c-ink-50) !important;
  border-color: var(--c-primary) !important;
}

/* 31. Bootstrap light badges in dark mode */
body.darkmode--activated .badge.text-bg-light,
body.darkmode--activated .badge.bg-light {
  background-color: var(--c-ink-100) !important;
  color: var(--c-ink-700) !important;
  border-color: var(--c-ink-200) !important;
}

/* ══════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:focus-visible { outline: none; box-shadow: var(--focus-ring); }
body {
  font-family: var(--font-body);
  background: var(--c-page);
  color: var(--c-ink-900);
  font-size: .8125rem;
  line-height: 1.5;
  display: flex;
  min-height: 100vh;
}

html,
body,
button,
input,
select,
textarea {
  font-family: var(--font-body);
}
.sidebar {
  width: var(--sidebar-w);
  flex: 0 0 var(--sidebar-w);
  background: linear-gradient(160deg, var(--c-sidebar-bg-start) 0%, var(--c-sidebar-bg-end) 100%);
  display: flex;
  flex-direction: column;
  height: 100vh;
  position: sticky;
  top: 0;
  padding: var(--sp-5) 14px var(--sp-4);
  gap: var(--sp-1);
}
.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 8px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  margin-bottom: 6px;
}
.sidebar-logo-icon {
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, var(--c-avatar-gradient-start), var(--c-avatar-gradient-end));
  border-radius: 7px;
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: .85rem;
  color: #fff;
  flex: 0 0 auto;
}
.sidebar-logo-name { font-family: var(--font-display); font-size: .9rem; font-weight: 700; color: #f1f5f9; }
.sidebar-section-label {
  font-size: .63rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(148, 163, 184, .65);
  padding: 8px 8px 3px;
}
.sidebar-section-label + .sidebar-section-label,
.nav-item + .sidebar-section-label { margin-top: var(--sp-2); }
.sidebar .nav-item:focus-visible {
  box-shadow: 0 0 0 2px rgba(147, 197, 253, .5);
  outline: none;
}
.nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 7px 10px;
  border-radius: 7px;
  color: rgba(226, 232, 240, .7);
  text-decoration: none;
  font-size: .82rem;
  font-weight: 500;
  transition: background .12s, color .12s;
  position: relative;
}
.nav-item:hover { background: rgba(255, 255, 255, .07); color: #f1f5f9; }
.nav-item.active {
  background: rgba(59, 130, 246, .18);
  color: #93c5fd;
  font-weight: 600;
}
.nav-item i { font-size: .95rem; flex: 0 0 auto; }
.nav-item.parent-active.active { background: rgba(59, 130, 246, .18); color: #93c5fd; }
.nav-item.parent-active { color: #e2e8f0; }
.nav-sub { padding-left: 24px; display: flex; flex-direction: column; gap: 1px; }
.nav-sub .nav-item { font-size: .78rem; padding: 5px 10px; }
.sidebar-footer {
  margin-top: auto;
  border-top: 1px solid rgba(255, 255, 255, .08);
  padding-top: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.sidebar-avatar {
  width: 28px;
  height: 28px;
  background: rgba(99, 102, 241, .35);
  border-radius: 7px;
  display: grid;
  place-items: center;
  font-size: .75rem;
  font-weight: 700;
  color: #a5b4fc;
  flex: 0 0 auto;
}
.sidebar-user-name { font-size: .78rem; color: #e2e8f0; font-weight: 500; }
.sidebar-user-role { font-size: .68rem; color: rgba(148, 163, 184, .65); }

.page-content { flex: 1; min-width: 0; padding: 0 24px 40px; overflow-y: auto; }
.page-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin: 20px 0 14px;
}
.page-head-actions { display: flex; gap: var(--sp-2); align-items: center; padding-top: 3px; flex-shrink: 0; }
.hint-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border: none;
  background: transparent;
  color: var(--c-ink-400);
  cursor: pointer;
  margin-left: 4px;
  vertical-align: middle;
}
.hint-icon:hover { color: var(--c-primary); }
.page-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  margin-bottom: var(--sp-1);
  font-size: .68rem;
  font-weight: 500;
  color: var(--c-ink-400);
}
.page-breadcrumb a { color: var(--c-ink-400); text-decoration: none; transition: color .12s; }
.page-breadcrumb a:hover { color: var(--c-primary); }
.bc-sep { color: var(--c-ink-200); font-size: .65rem; line-height: 1; }
.bc-leaf {
  color: var(--c-primary);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.page-title { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; line-height: 1.2; }
.page-subtitle { font-size: .8rem; color: var(--c-ink-400); margin-top: 3px; max-width: 680px; }

.btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 13px;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid transparent;
  text-decoration: none;
  transition: all .12s;
  white-space: nowrap;
  line-height: 1;
  min-height: 32px;
}
.btn-sm { padding: 4px 10px; font-size: .76rem; min-height: 28px; }
.btn-primary { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }
.btn-primary:hover { background: var(--c-primary-dim); }
.btn-success { background: var(--c-ok); color: #fff; border-color: var(--c-ok); }
.btn-success:hover { background: #047857; }
.btn-outline { background: transparent; color: var(--c-ink-500); border-color: var(--c-ink-200); }
.btn-outline:hover { border-color: var(--c-ink-400); color: var(--c-ink-700); background: var(--c-ink-50); }
.btn-outline-secondary { background: transparent; color: var(--c-ink-500); border-color: var(--c-ink-200); }
.btn-outline-secondary:hover { border-color: var(--c-ink-400); color: var(--c-ink-700); background: var(--c-ink-50); }
.btn-outline-primary { background: transparent; color: var(--c-primary); border-color: var(--c-primary-border); }
.btn-outline-primary:hover { background: var(--c-primary-soft); }
.btn-ghost { background: transparent; color: var(--c-ink-400); border: 1px solid transparent; }
.btn-ghost:hover { background: var(--c-ink-50); color: var(--c-ink-700); }

.card, .panel-card, .form-card, .table-card, .summary-card {
  background: var(--c-card);
  border: 1px solid var(--c-ink-100);
  border-radius: var(--radius-card);
}
.panel-card, .form-card, .summary-card { padding: 14px 16px; }
.table-card { overflow: hidden; margin-bottom: 14px; }
.table-card-head {
  padding: 11px 16px;
  border-bottom: 1px solid var(--c-ink-100);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.table-card-title { font-family: var(--font-display); font-size: .88rem; font-weight: 700; }

.t { width: 100%; border-collapse: collapse; }
.t th {
  padding: 8px 12px;
  font-size: .67rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--c-ink-400);
  border-bottom: 1px solid var(--c-ink-100);
  background: var(--c-ink-50);
  white-space: nowrap;
  text-align: left;
}
.t td { padding: 9px 12px; border-bottom: 1px solid var(--c-ink-50); vertical-align: top; font-size: .8rem; }
.t tbody tr:last-child td { border-bottom: none; }
.t tbody tr:hover td { background: var(--c-ink-50); }

.badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 1px 8px;
  border-radius: 4px;
  font-size: .67rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  white-space: nowrap;
}
.badge-ok { background: var(--c-ok-soft); color: var(--c-ok); border: 1px solid var(--c-ok-border); }
.badge-neg { background: var(--c-neg-soft); color: var(--c-neg); border: 1px solid var(--c-neg-border); }
.badge-warn { background: var(--c-warn-soft); color: var(--c-warn); border: 1px solid var(--c-warn-border); }
.badge-muted { background: var(--c-ink-50); color: var(--c-ink-500); border: 1px solid var(--c-ink-200); }

.form-row2, .form-row3, .form-row4 {
  display: grid;
  gap: 12px;
}
.form-row2 { grid-template-columns: 1fr 1fr; }
.form-row3 { grid-template-columns: repeat(3, 1fr); }
.form-row4 { grid-template-columns: repeat(4, 1fr); }
.form-field { display: flex; flex-direction: column; gap: 4px; }
.form-label {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--c-ink-500);
}
.form-input, .form-select, .form-textarea {
  border: 1px solid var(--c-ink-200);
  border-radius: var(--radius-sm);
  padding: 7px 10px;
  font-family: var(--font-body);
  font-size: .8rem;
  color: var(--c-ink-900);
  background: #fff;
  outline: none;
  width: 100%;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, .08);
}
.form-textarea { resize: vertical; min-height: 90px; }
.form-note { font-size: .72rem; color: var(--c-ink-400); margin-top: 2px; }

/* Bridge Bootstrap form widgets to prototype form look. */
.form-control,
.form-select,
select.form-select,
input.form-control,
textarea.form-control {
  border: 1px solid var(--c-ink-200);
  border-radius: var(--radius-sm);
  padding: 7px 10px;
  font-family: var(--font-body);
  font-size: .8rem;
  color: var(--c-ink-900);
  background: #fff;
  box-shadow: none;
}

textarea.form-control {
  min-height: 96px;
  resize: vertical;
}

.form-control:focus,
.form-select:focus,
select.form-select:focus,
input.form-control:focus,
textarea.form-control:focus {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, .08);
}

.form-control[readonly] {
  background: var(--c-ink-50);
  color: var(--c-ink-500);
}

.form-field input:not([type="checkbox"]),
.form-field select,
.form-field textarea {
  width: 100%;
  border: 1px solid var(--c-ink-200);
  border-radius: var(--radius-sm);
  padding: 7px 10px;
  font-family: var(--font-body);
  font-size: .8rem;
  color: var(--c-ink-900);
  background: #fff;
  box-shadow: none;
}

.form-field input:not([type="checkbox"]):focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 2px rgba(37, 99, 235, .08);
  outline: none;
}

.form-check-input {
  width: 1rem;
  height: 1rem;
  border: 1px solid var(--c-ink-200);
  border-radius: .25rem;
}

.form-check-input:checked {
  background-color: var(--c-primary);
  border-color: var(--c-primary);
}

.filters-inline { display: flex; gap: 8px; flex-wrap: wrap; align-items: end; }
.filters-inline .form-field select,
.filters-inline .form-field input[type="date"],
.filters-inline .form-field input[type="text"],
.filters-inline .form-field input[type="search"] {
  height: 30px;
  padding: 0 9px;
  font-size: .78rem;
  line-height: 1.2;
}
.actions-group { display: flex; gap: 5px; justify-content: flex-end; }
.sep { border: none; border-top: 1px solid var(--c-ink-100); margin: 12px 0; }
.alert {
  border-radius: 8px;
  border: 1px solid var(--c-ink-100);
  background: #fff;
  padding: 10px 12px;
  margin-bottom: 12px;
}
.alert-info { background: #eff6ff; border-color: #bfdbfe; color: #1e40af; }
.alert-warning { background: #fffbeb; border-color: #fde68a; color: #92400e; }
.alert-danger { background: #fee2e2; border-color: #fecaca; color: #991b1b; }

.wizard-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}
.wizard-step {
  border: 1px solid var(--c-ink-200);
  border-radius: var(--radius-sm);
  background: #fff;
  padding: 6px 8px;
  font-size: .75rem;
  color: var(--c-ink-500);
  text-align: center;
}
.wizard-step.is-active {
  background: var(--c-primary-soft);
  color: var(--c-primary-dim);
  border-color: var(--c-primary-border);
  font-weight: 700;
}
.wizard-step.is-done { background: #f8fafc; color: #334155; border-color: #cbd5e1; }

.dropzone {
  border: 1px dashed var(--c-ink-200);
  border-radius: var(--radius-card);
  background: #fcfdff;
  padding: 14px;
}
.dropzone-title { font-weight: 600; color: var(--c-ink-700); }
.dropzone-meta { font-size: .75rem; color: var(--c-ink-400); margin-top: 4px; }

.modal-backdrop {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, .4);
  z-index: 100;
}
.modal-backdrop.is-open { display: flex; }
.modal-box {
  width: min(720px, 94vw);
  max-height: 88vh;
  overflow: auto;
  border: 1px solid var(--c-ink-100);
  border-radius: var(--radius-card);
  background: #fff;
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--c-ink-100);
}
.modal-title { font-family: var(--font-display); font-size: 1rem; font-weight: 700; }
.modal-body { padding: 14px 16px; }
.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 10px 16px;
  border-top: 1px solid var(--c-ink-100);
}

.progress {
  height: 10px;
  background: #e2e8f0;
  border-radius: 999px;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  width: 55%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--c-primary), var(--c-avatar-gradient-start));
}

.chart-block {
  border: 1px solid var(--c-ink-100);
  border-radius: var(--radius-card);
  background: #fff;
  padding: 10px;
  min-height: 260px;
}
.chart-canvas {
  margin-top: 10px;
  border: 1px dashed var(--c-ink-200);
  border-radius: 8px;
  min-height: 170px;
  display: grid;
  place-items: center;
  color: var(--c-ink-400);
  font-size: .75rem;
}

.mobile-nav-toggle,
.mobile-nav-backdrop {
  display: none;
}

@media (max-width: 1024px) {
  body { display: block; }
  .mobile-nav-toggle {
    position: fixed;
    top: 12px;
    left: 12px;
    width: 34px;
    height: 34px;
    border: 1px solid var(--c-ink-200);
    border-radius: 8px;
    background: #fff;
    color: var(--c-ink-700);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 520;
    box-shadow: 0 8px 22px rgba(15, 23, 42, .14);
  }
  .mobile-nav-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, .45);
    opacity: 0;
    pointer-events: none;
    transition: opacity .16s ease;
    z-index: 500;
    display: block;
  }
  .sidebar {
    position: fixed !important;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(82vw, var(--sidebar-w));
    height: 100vh;
    transform: translateX(-100%);
    transition: transform .18s ease;
    z-index: 510;
    box-shadow: 0 18px 46px rgba(15, 23, 42, .3);
  }
  .page-content { padding: 0 14px 24px; }
  .page-head { flex-direction: column; margin: 10px 0 10px; }
  .page-head-actions .btn-ghost { display: none; }
  body.mobile-nav-open .sidebar { transform: translateX(0); }
  body.mobile-nav-open .mobile-nav-backdrop {
    opacity: 1;
    pointer-events: auto;
  }
}

@media (max-width: 780px) {
  .form-row2, .form-row3, .form-row4 { grid-template-columns: 1fr; }
}

/* Compatibility layer for Django base wrapper classes. */
.menu-preview-layout {
  display: flex;
  min-height: 100vh;
  background: var(--c-page);
  width: 100%;
  max-width: none !important;
  flex: 1 1 auto;
}

html,
body,
#body-pd,
#menuLayout {
  width: 100%;
  max-width: none !important;
}

#menuLayout.menu-preview-layout {
  min-width: 100%;
}

.menu-preview-sidebar.sidebar {
  width: var(--sidebar-w) !important;
  flex: 0 0 var(--sidebar-w) !important;
  position: sticky !important;
  top: 0;
  bottom: auto !important;
  padding: 20px 14px 16px !important;
  gap: 4px !important;
  height: 100vh !important;
  z-index: auto !important;
  overflow: visible !important;
  border-radius: 0 !important;
  border: 0 !important;
  background: linear-gradient(160deg, var(--c-sidebar-bg-start) 0%, var(--c-sidebar-bg-end) 100%) !important;
  transform: none !important;
  box-shadow: none !important;
}

.menu-preview-sidebar.sidebar::after {
  display: none !important;
}

.menu-preview-sidebar.sidebar > * {
  position: static !important;
  z-index: auto !important;
}

.menu-preview-main.page-content {
  flex: 1;
  min-width: 0;
  width: auto !important;
  max-width: none !important;
  padding: 0 24px 40px;
  overflow-y: auto;
}

#page-content-wrapper,
#page-content-wrapper.menu-preview-main {
  margin-left: 0 !important;
  width: auto !important;
}

#page-content-wrapper > .page-shell {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

.menu-preview-layout.menu-preview-collapsed .menu-preview-sidebar.sidebar {
  width: var(--sidebar-w) !important;
  padding: 20px 14px 16px !important;
}

.menu-preview-layout.menu-preview-collapsed .sidebar .sidebar-logo-name,
.menu-preview-layout.menu-preview-collapsed .sidebar .sidebar-section-label,
.menu-preview-layout.menu-preview-collapsed .sidebar .nav-item span,
.menu-preview-layout.menu-preview-collapsed .sidebar .sidebar-footer > div:last-child {
  display: block !important;
}

.menu-preview-toggle,
#menuCollapseToggle,
#menuUserPopoverContent {
  display: none !important;
}

.darkmode-toggle,
.darkmode-toggle--active,
.darkmode-toggle--inactive {
  display: none !important;
}

@media (max-width: 991px) {
  .menu-preview-layout {
    display: block;
  }

  body.menu-mobile-lock {
    overflow: hidden !important;
  }

  .menu-preview-mobile-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    background: #ffffff;
    border-bottom: 1px solid #e2e8f0;
    z-index: 1300;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.08);
  }

  .menu-preview-mobile-toggle {
    border: none;
    background: var(--c-sidebar-bg-start);
    color: #fff;
    border-radius: 12px;
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
  }

  .menu-preview-sidebar.sidebar {
    position: fixed !important;
    top: 0;
    left: 0;
    right: auto !important;
    bottom: 0;
    max-width: 280px;
    width: min(82vw, 280px);
    height: 100vh !important;
    transform: translateX(-100%) !important;
    transition: transform .18s ease;
    z-index: 1400 !important;
    border-radius: 0 !important;
  }

  .menu-preview-main.page-content {
    padding: 72px 14px 88px;
  }

  .menu-preview-layout.menu-preview-mobile-open .menu-preview-sidebar.sidebar {
    transform: translateX(0) !important;
  }

  .menu-preview-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    opacity: 0;
    pointer-events: none;
    transition: opacity .16s ease;
    z-index: 1300;
  }

  .menu-preview-layout.menu-preview-mobile-open .menu-preview-backdrop {
    opacity: 1;
    pointer-events: auto;
  }
  .sidebar-cmd-keys { display: none; }
}

/* ---- Command Palette ---- */

.cmd-palette-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, .45);
  z-index: 9000;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding-top: min(18vh, 140px);
}
.cmd-palette-backdrop.is-open {
  display: flex;
}
.cmd-palette {
  width: min(540px, 94vw);
  max-height: min(420px, 70vh);
  background: var(--c-card);
  border: 1px solid var(--c-ink-100);
  border-radius: var(--radius-card);
  box-shadow: 0 20px 60px rgba(15, 23, 42, .25), 0 0 0 1px rgba(15, 23, 42, .05);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: cmdPaletteIn .12s ease-out;
}
@keyframes cmdPaletteIn {
  from { opacity: 0; transform: scale(.98) translateY(-6px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.cmd-palette-input-wrap {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--c-ink-100);
}
.cmd-palette-input-wrap > i {
  color: var(--c-ink-400);
  font-size: 1rem;
  flex: 0 0 auto;
}
.cmd-palette-input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: var(--font-body);
  font-size: .9rem;
  color: var(--c-ink-900);
  min-width: 0;
}
.cmd-palette-input::placeholder { color: var(--c-ink-400); }
.cmd-palette-hint {
  font-size: .65rem;
  color: var(--c-ink-400);
  white-space: nowrap;
  flex: 0 0 auto;
}
.cmd-palette-results {
  overflow-y: auto;
  padding: var(--sp-1) 0;
}
.cmd-palette-group {
  font-size: .63rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-ink-400);
  padding: var(--sp-2) var(--sp-4) var(--sp-1);
}
.cmd-palette-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 7px var(--sp-4);
  color: var(--c-ink-700);
  text-decoration: none;
  font-size: .82rem;
  cursor: pointer;
  transition: background .08s;
}
.cmd-palette-item i {
  font-size: .9rem;
  color: var(--c-ink-400);
  width: 18px;
  text-align: center;
  flex: 0 0 auto;
}
.cmd-palette-item:hover,
.cmd-palette-item.is-active {
  background: var(--c-primary-soft);
  color: var(--c-ink-900);
}
.cmd-palette-item.is-active i { color: var(--c-primary); }
.cmd-palette-item-label { flex: 1; min-width: 0; }
.cmd-palette-item-hint {
  font-size: .68rem;
  color: var(--c-ink-400);
  flex: 0 0 auto;
}
.cmd-palette-empty {
  padding: var(--sp-6) var(--sp-4);
  text-align: center;
  color: var(--c-ink-400);
  font-size: .82rem;
}

/* ---- Sidebar command palette trigger ---- */
.sidebar-cmd-trigger {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  width: 100%;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 8px;
  padding: 7px 10px;
  color: rgba(148, 163, 184, .7);
  font-family: var(--font-body);
  font-size: .78rem;
  cursor: pointer;
  transition: background .14s, border-color .14s;
  margin: var(--sp-2) 0 var(--sp-3);
  text-align: left;
}
.sidebar-cmd-trigger:hover {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .18);
  color: rgba(148, 163, 184, 1);
}
.sidebar-cmd-trigger i { font-size: .82rem; flex-shrink: 0; }
.sidebar-cmd-trigger-label { flex: 1; }
.sidebar-cmd-keys { display: flex; gap: 2px; }
.sidebar-cmd-keys kbd {
  background: rgba(255, 255, 255, .08);
  border-radius: 3px;
  padding: 1px 5px;
  font-size: .6rem;
  font-family: inherit;
  color: rgba(148, 163, 184, .55);
}

/* ---- Sidebar user menu ---- */
.sidebar-footer { position: relative !important; }
.menu-preview-sidebar.sidebar .sidebar-footer { position: relative !important; }
.sidebar-user-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: none;
  border: none;
  padding: 4px 4px;
  cursor: pointer;
  text-align: left;
  border-radius: 6px;
  transition: background .12s;
}
.sidebar-user-btn:hover { background: rgba(255, 255, 255, .05); }
.sidebar-user-info { flex: 1; min-width: 0; overflow: hidden; }
.sidebar-user-chevron {
  font-size: .72rem;
  color: rgba(148, 163, 184, .4);
  transition: transform .14s;
  flex-shrink: 0;
}
.sidebar-footer.is-open .sidebar-user-chevron { transform: rotate(180deg); }
.sidebar-user-menu {
  display: none;
  position: absolute;
  bottom: calc(100% + 6px);
  left: 0;
  right: 0;
  background: #1e293b;
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 8px;
  padding: 4px;
  box-shadow: 0 -8px 24px rgba(0, 0, 0, .35);
  z-index: 20;
}
.sidebar-footer.is-open .sidebar-user-menu { display: block; }
.sidebar-user-menu-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 7px 10px;
  border-radius: 5px;
  font-size: .78rem;
  color: rgba(148, 163, 184, .85);
  text-decoration: none;
  transition: background .1s, color .1s;
}
.sidebar-user-menu-item:hover { background: rgba(255, 255, 255, .07); color: #e2e8f0; }
.sidebar-user-menu-item--danger:hover { background: rgba(185, 28, 28, .15); color: #fca5a5; }

/* User menu — section label */
.sidebar-user-menu-label {
  display: block;
  font-size: .58rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(148, 163, 184, .45);
  padding: 6px 10px 3px;
}

/* User menu — divider */
.sidebar-user-menu-divider {
  height: 1px;
  background: rgba(255, 255, 255, .07);
  margin: 4px 2px;
}

/* Theme toggle — 2-col button row */
.sidebar-theme-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  padding: 0 4px 6px;
}
.sidebar-theme-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  font-size: .72rem;
  font-family: var(--font-body);
  color: rgba(148, 163, 184, .65);
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 6px;
  padding: 5px 8px;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}
.sidebar-theme-btn:hover {
  background: rgba(255, 255, 255, .1);
  color: #e2e8f0;
}
.sidebar-theme-btn.active {
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .22);
  color: #f1f5f9;
}

/* Language picker — pill row */
.sidebar-lang-row {
  display: flex;
  gap: 3px;
  padding: 0 4px 6px;
}
.sidebar-lang-btn {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .67rem;
  font-weight: 600;
  font-family: var(--font-body);
  letter-spacing: .04em;
  color: rgba(148, 163, 184, .65);
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 5px;
  padding: 4px 6px;
  text-decoration: none;
  transition: background .12s, color .12s, border-color .12s;
}
.sidebar-lang-btn:hover {
  background: rgba(255, 255, 255, .1);
  color: #e2e8f0;
}
.sidebar-lang-btn.active {
  background: rgba(99, 102, 241, .22);
  border-color: rgba(99, 102, 241, .38);
  color: #a5b4fc;
}

/* Settings: users */
.settings-users-page .table-card-meta {
  font-size: 0.75rem;
  color: var(--c-ink-400);
}

.settings-users-page .user-cell {
  display: flex;
  align-items: center;
  gap: 9px;
}

.settings-users-page .user-avatar {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  font-size: 0.72rem;
  font-weight: 700;
  flex: 0 0 auto;
  color: #fff;
  background: linear-gradient(135deg, #3b82f6, #6366f1);
}

.settings-users-page .user-handle {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--c-ink-900);
  line-height: 1.2;
}

.settings-users-page .user-email-small {
  font-size: 0.72rem;
  color: var(--c-ink-400);
  line-height: 1.2;
}

.settings-users-page .row-actions {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}

.settings-users-page .btn-neg {
  background: transparent;
  color: var(--c-neg);
  border-color: #fca5a5;
}

.settings-users-page .btn-neg:hover {
  background: var(--c-neg-soft);
  border-color: var(--c-neg);
}

.settings-users-page .btn-ok {
  background: transparent;
  color: var(--c-ok);
  border-color: var(--c-ok-border);
}

.settings-users-page .btn-ok:hover {
  background: var(--c-ok-soft);
  border-color: var(--c-ok);
}

.settings-users-page .inline-form {
  display: inline;
}
