:root{
  --dg-ink:#0f172a;
  --dg-muted:#64748b;
  --dg-subtle:#5f6e65;
  --dg-bg:#ffffff;
  --dg-surface:#ffffff;
  --dg-surface-2:#f8fafc;
  --dg-surface-3:#edf7f0;
  --dg-border:rgba(2,6,23,.08);
  --dg-border-strong:rgba(2,6,23,.16);
  --dg-glass:rgba(255,255,255,.78);
  --dg-overlay:rgba(255,255,255,.72);
  --dg-shadow:0 10px 30px rgba(2,6,23,.06);
  --dg-shadow-strong:0 18px 40px rgba(2,6,23,.12);
  --dg-border-accent:rgba(22,163,74,.16);
  --dg-footer:rgba(255,255,255,.88);
  --dg-hover:rgba(22,163,74,.08);
  --dg-hover-strong:rgba(22,163,74,.16);
  --dg-focus:rgba(34,197,94,.22);
  --dg-link:#15803d;
  --dg-link-hover:#166534;
  --dg-success:#15803d;
  --dg-success-soft:rgba(22,163,74,.14);
  --dg-warning:#b45309;
  --dg-warning-soft:rgba(245,158,11,.18);
  --dg-danger:#dc2626;
  --dg-danger-soft:rgba(220,38,38,.12);
  --dg-info:#0f766e;
  --dg-info-soft:rgba(13,148,136,.12);
  --dg-input-bg:#f8fcf8;
  --dg-input-border:rgba(15,23,42,.16);
  --dg-input-border-strong:rgba(22,163,74,.34);
  --dg-input-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 1px 2px rgba(15,23,42,.04);
  --dg-placeholder:#6b7280;
  --dg-page-gradient:
    radial-gradient(420px 280px at 8% 0%, rgba(34,197,94,.12), transparent 70%),
    radial-gradient(360px 280px at 100% 12%, rgba(45,212,191,.12), transparent 70%),
    linear-gradient(180deg, rgba(248,250,252,.86), rgba(255,255,255,1));
  --dg-chart-text:#0f172a;
  --dg-chart-grid:rgba(15,23,42,.08);
  --dg-chart-1:#16a34a;
  --dg-chart-2:#22c55e;
  --dg-chart-3:#14b8a6;
  --dg-chart-4:#f59e0b;
  --dg-chart-5:#ef4444;
  --dg-chat-thread:rgba(248,250,252,.94);
  --dg-chat-support:rgba(220,252,231,.95);
  --dg-chat-client:#ffffff;

  --dg-g1:#16a34a;
  --dg-g2:#22c55e;
  --dg-g3:#2dd4bf;

  --dg-header-h: 74px;

  --dg-sidebar-w: 200px;
  --dg-sidebar-w-collapsed: 78px;
  --dg-sidebar-resizer-w: 14px;
}

html[data-theme="dark"]{
  color-scheme: dark;
  --dg-ink:#ecfdf3;
  --dg-muted:#9dc8aa;
  --dg-subtle:#c6ddd0;
  --dg-bg:#06110c;
  --dg-surface:#0b1711;
  --dg-surface-2:#112019;
  --dg-surface-3:#172921;
  --dg-border:rgba(183,247,199,.2);
  --dg-border-strong:rgba(183,247,199,.35);
  --dg-glass:rgba(9,19,14,.82);
  --dg-overlay:rgba(7,17,12,.84);
  --dg-shadow:0 10px 30px rgba(0,0,0,.6);
  --dg-shadow-strong:0 18px 40px rgba(0,0,0,.7);
  --dg-border-accent:rgba(183,247,199,.28);
  --dg-footer:rgba(11,23,17,.84);
  --dg-hover:rgba(34,197,94,.12);
  --dg-hover-strong:rgba(45,212,191,.18);
  --dg-focus:rgba(74,222,128,.28);
  --dg-link:#86efac;
  --dg-link-hover:#bbf7d0;
  --dg-success:#4ade80;
  --dg-success-soft:rgba(34,197,94,.16);
  --dg-warning:#fbbf24;
  --dg-warning-soft:rgba(251,191,36,.18);
  --dg-danger:#fb7185;
  --dg-danger-soft:rgba(244,63,94,.16);
  --dg-info:#67e8f9;
  --dg-info-soft:rgba(103,232,249,.16);
  --dg-input-bg:#102019;
  --dg-input-border:rgba(157,200,170,.28);
  --dg-input-border-strong:rgba(74,222,128,.5);
  --dg-input-shadow:inset 0 1px 0 rgba(255,255,255,.02), 0 8px 18px rgba(0,0,0,.14);
  --dg-placeholder:#afc3b5;
  --dg-page-gradient:
    radial-gradient(540px 380px at 10% 0%, rgba(34,197,94,.14), transparent 70%),
    radial-gradient(480px 360px at 100% 10%, rgba(45,212,191,.12), transparent 70%),
    linear-gradient(180deg, rgba(6,17,12,.98), rgba(4,10,7,1));
  --dg-chart-text:#ecfdf3;
  --dg-chart-grid:rgba(157,200,170,.18);
  --dg-chart-1:#34d399;
  --dg-chart-2:#60a5fa;
  --dg-chart-3:#fbbf24;
  --dg-chart-4:#fb7185;
  --dg-chart-5:#a78bfa;
  --dg-chat-thread:rgba(10,21,15,.92);
  --dg-chat-support:rgba(18,65,44,.74);
  --dg-chat-client:rgba(17,24,39,.84);
}

body{
  background-color: var(--dg-bg);
  background-image: var(--dg-page-gradient);
  background-attachment: fixed;
  color: var(--dg-ink);
}

html[data-theme="dark"] body{
  background-color: var(--dg-bg) !important;
  background-image: var(--dg-page-gradient) !important;
  color: var(--dg-ink) !important;
}

html[data-theme="dark"] .layout-wrapper,
html[data-theme="dark"] .layout-container,
html[data-theme="dark"] .layout-page,
html[data-theme="dark"] .content-wrapper,
html[data-theme="dark"] .wrapper{
  background: transparent !important;
}

html[data-theme="dark"] .content-wrapper{
  background-color: transparent !important;
  background-image: none !important;
}

/* =========================
   LAYOUT (flex) - NO GAPS
========================= */
.layout-wrapper.layout-content-navbar{
  padding-top: var(--dg-header-h) !important; /* push under fixed header */
}

.layout-wrapper .layout-container{
  display:flex !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: 100% !important;
}

.layout-wrapper .layout-container > .scrollbar.side-menu-bg{
  width: var(--dg-sidebar-w) !important;
  flex: 0 0 var(--dg-sidebar-w) !important;
}

/* ✅ RTL: sidebar on RIGHT */
html[dir="rtl"] .layout-wrapper .layout-container{
  flex-direction: row-reverse !important;
}

.layout-menu{
  width: var(--dg-sidebar-w) !important;
  flex: 0 0 var(--dg-sidebar-w) !important;

  position: sticky !important;
  top: var(--dg-header-h) !important;
  height: calc(100vh - var(--dg-header-h)) !important;
  z-index: 3000 !important;
}

.layout-page{
  flex: 1 1 auto !important;
  min-width: 0 !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* remove any template margin that creates a gap */
.layout-page,
.content-wrapper{
  margin: 0 !important;
}

.content-wrapper{
  width: 100% !important;
  max-width: none !important;
  padding: 18px 22px 0 !important;
  overflow: visible !important;
}

/* Legacy employee dashboard layout */
.wrapper .side-menu-fixed{
  width: var(--dg-sidebar-w) !important;
  height: calc(100vh - var(--dg-header-h)) !important;
  top: var(--dg-header-h) !important;
  z-index: 3000 !important;
}
html[dir="rtl"] .wrapper .side-menu-fixed{
  right: 0 !important;
  left: auto !important;
}
html[dir="ltr"] .wrapper .side-menu-fixed{
  left: 0 !important;
  right: auto !important;
}
html[dir="rtl"] .wrapper .content-wrapper{
  margin-right: var(--dg-sidebar-w) !important;
  width: auto !important;
  margin-left: 0 !important;
  padding-right: 22px !important;
}
html[dir="ltr"] .wrapper .content-wrapper{
  margin-left: var(--dg-sidebar-w) !important;
  width: auto !important;
  margin-right: 0 !important;
  padding-left: 22px !important;
}

/* =========================
   TOPBAR ALWAYS ABOVE ALL
========================= */
.admin-header{
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 6000 !important;
  overflow: visible !important;

  background: var(--dg-glass) !important;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--dg-border-accent) !important;
}

/* prevent dropdown clipping */
.layout-wrapper,
.layout-container,
.layout-page,
.content-wrapper,
.navbar,
nav{
  overflow: visible !important;
  transform: none !important;
}
.dropdown-menu{ z-index: 9999 !important; }

/* =========================
   SIDEBAR BASE (LIGHT)
========================= */
.side-menu-fixed{
  width: 100% !important;
  height: 100% !important;
  padding: 10px 8px !important;

  background-image:
    radial-gradient(420px 280px at 85% 12%, rgba(34,197,94,.12), transparent 70%),
    radial-gradient(420px 280px at 12% 92%, rgba(45,212,191,.10), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.98)) !important;

  border-inline-end: 1px solid rgba(22,163,74,.14) !important;
  box-shadow: 2px 0 22px rgba(2,6,23,.06) !important;

  overflow: hidden !important; /* prevent gutter strip */
}

/* inner scroll panel */
.side-menu-bg,
.scrollbar.side-menu-bg{
  height: 100% !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  position: relative;

  background: rgba(255,255,255,.78) !important;
  border: 1px solid rgba(2,6,23,.06) !important;
  border-radius: 18px !important;

  margin: 0 !important;          /* ✅ no extra space */
  padding: 10px 6px !important;  /* ✅ tighter */
  box-shadow: 0 10px 26px rgba(2,6,23,.05) !important;
}

/* remove legacy backgrounds */
.scrollbar,
.navbar-nav.side-menu,
.nav.side-menu{ background: transparent !important; }

.diagri-sidebar-resizer{
  position: absolute;
  top: 14px;
  bottom: 14px;
  right: 0;
  width: var(--dg-sidebar-resizer-w);
  cursor: col-resize;
  z-index: 25;
  touch-action: none;
}
html[dir="rtl"] .diagri-sidebar-resizer{
  left: 0;
  right: auto;
}
.diagri-sidebar-resizer::before{
  content:"";
  position:absolute;
  top: 10px;
  bottom: 10px;
  right: 4px;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(22,163,74,.12), rgba(45,212,191,.42), rgba(22,163,74,.12));
  box-shadow: 0 0 0 1px rgba(22,163,74,.08);
  opacity: .42;
  transition: opacity .18s ease, transform .18s ease, background .18s ease;
}
html[dir="rtl"] .diagri-sidebar-resizer::before{
  left: 4px;
  right: auto;
}
.diagri-sidebar-resizer:hover::before,
body.sidebar-resizing .diagri-sidebar-resizer::before{
  opacity: .92;
  transform: scaleX(1.15);
}
body.sidebar-collapsed .diagri-sidebar-resizer{
  opacity: 0;
  pointer-events: none;
}
body.sidebar-resizing,
body.sidebar-resizing *{
  cursor: col-resize !important;
  user-select: none !important;
}

/* section titles */
.menu-title{
  color: rgba(100,116,139,.95) !important;
  padding: 10px 6px 6px !important;
  font-size: 11px !important;
  font-weight: 1000 !important;
  letter-spacing: .7px !important;
  text-transform: uppercase !important;
}

/* =========================
   MENU ITEMS
========================= */
.side-menu li a.menu-link,
.side-menu li a{
  position: relative;

  display:flex !important;
  align-items:center !important;
  gap:10px !important;

  width: 100% !important;
  padding: 10px 10px !important;
  margin: 6px 0 !important;          /* ✅ flush to edges */
  border-radius: 16px !important;

  text-decoration:none !important;
  font-weight: 900 !important;
  font-size: 13px !important;

  color: var(--dg-ink) !important;
  border: 1px solid rgba(2,6,23,.06) !important;
  background: rgba(255,255,255,.88) !important;

  transition: background .18s ease, transform .18s ease, box-shadow .2s ease, border-color .2s ease;
}

/* RTL: icon on right */
html[dir="rtl"] .side-menu li a.menu-link,
html[dir="rtl"] .side-menu li a{
  flex-direction: row !important;
  direction: rtl;
  justify-content: flex-start !important;
  text-align: right !important;
}
html[dir="rtl"] .side-menu li a .icon-wrap{
  margin-left: 8px;
  margin-right: 0;
}
html[dir="rtl"] .side-menu li a .right-nav-text{
  text-align: right;
}

/* icon wrap */
.icon-wrap{
  width:32px;height:32px;
  border-radius: 14px;

  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;

  background: rgba(15,23,42,.04) !important;
  border: 1px solid rgba(2,6,23,.06) !important;
  color: var(--dg-g1) !important;

  flex: 0 0 auto !important;
}
.icon-wrap i{ font-size:16px; line-height:1; }

/* label */
.right-nav-text{
  min-width:0;
  display:-webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow:hidden;
}

/* hover */
.side-menu li a:hover{
  background: linear-gradient(135deg, rgba(34,197,94,.12), rgba(45,212,191,.08), rgba(255,255,255,.90)) !important;
  border-color: rgba(34,197,94,.18) !important;
  box-shadow: 0 14px 26px rgba(34,197,94,.10) !important;
  transform: translateY(-1px);
}

/* active */
.side-menu li.active > a,
.side-menu li > a.active{
  background: linear-gradient(135deg, rgba(34,197,94,.18), rgba(45,212,191,.10), rgba(255,255,255,.92)) !important;
  border-color: rgba(34,197,94,.26) !important;
  box-shadow: 0 18px 32px rgba(34,197,94,.14) !important;
}

.side-menu li.active > a::before,
.side-menu li > a.active::before{
  content:"";
  position:absolute;
  top:10px; bottom:10px;
  width:4px;
  border-radius:999px;
  background: linear-gradient(180deg, var(--dg-g2), var(--dg-g3));
  left: 6px;
}
html[dir="rtl"] .side-menu li.active > a::before,
html[dir="rtl"] .side-menu li > a.active::before{
  left:auto;
  right: 6px;
}

/* submenu */
.side-menu ul.collapse{ padding: 6px 0 10px !important; }
.side-menu ul.collapse li a{
  border-radius: 14px !important;
  font-size: 12.5px !important;
  background: rgba(255,255,255,.80) !important;
}

/* arrow */
.collapse-arrow{
  margin-inline-start:auto !important;
  width:22px;height:22px;
  border-radius: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(2,6,23,.06);
  color: rgba(15,23,42,.60);
  font-size:0;
  transition: transform .18s ease;
}
.collapse-arrow::before{
  content:"›";
  font-size:16px;
  font-weight:1000;
  line-height:1;
  transform: translateY(-1px);
}
a[aria-expanded="true"] .collapse-arrow{ transform: rotate(90deg); }

/* =========================
   COLLAPSED SIDEBAR
========================= */
body.sidebar-collapsed .layout-menu{
  width: var(--dg-sidebar-w-collapsed) !important;
  flex: 0 0 var(--dg-sidebar-w-collapsed) !important;
}

body.sidebar-collapsed .wrapper .side-menu-fixed{
  width: var(--dg-sidebar-w-collapsed) !important;
}
html[dir="rtl"] body.sidebar-collapsed .wrapper .content-wrapper{
  margin-right: var(--dg-sidebar-w-collapsed) !important;
}
html[dir="ltr"] body.sidebar-collapsed .wrapper .content-wrapper{
  margin-left: var(--dg-sidebar-w-collapsed) !important;
}

body.sidebar-collapsed .layout-wrapper .layout-container > .scrollbar.side-menu-bg{
  width: var(--dg-sidebar-w-collapsed) !important;
  flex: 0 0 var(--dg-sidebar-w-collapsed) !important;
}

body.sidebar-collapsed .right-nav-text,
body.sidebar-collapsed .menu-title,
body.sidebar-collapsed .collapse-arrow{
  display:none !important;
}

body.sidebar-collapsed .side-menu li a{
  justify-content:center !important;
  gap: 0 !important;
  padding: 10px 0 !important;
}

body.sidebar-collapsed .icon-wrap{
  width: 38px !important;
  height: 38px !important;
  border-radius: 16px !important;
  display:inline-flex !important; /* ✅ keep icon visible */
}

/* ✅ remove any sidebar internal toggle if still exists somewhere */
#sidebarToggle{ display:none !important; }

/* =========================
   THEME OVERRIDES (DARK)
========================= */
html[data-theme="dark"] .diagri-topbar::before{
  background: radial-gradient(circle at 30% 30%, rgba(5,5,5,.85), rgba(34,197,94,.22) 45%, rgba(183,247,199,.12) 70%, transparent 100%);
  border-color: rgba(183,247,199,.2);
}
html[data-theme="dark"] .diagri-topbar::after{
  border-color: rgba(183,247,199,.28);
  background: linear-gradient(90deg, rgba(34,197,94,.14), rgba(183,247,199,.08), rgba(34,197,94,.14));
}
html[data-theme="dark"] .side-menu-fixed{
  background-image:
    radial-gradient(420px 280px at 85% 12%, rgba(34,197,94,.18), transparent 70%),
    radial-gradient(420px 280px at 12% 92%, rgba(183,247,199,.14), transparent 70%),
    linear-gradient(180deg, rgba(5,5,5,.98), rgba(10,10,10,.98)) !important;
  border-inline-end: 1px solid var(--dg-border) !important;
  box-shadow: 2px 0 22px rgba(0,0,0,.45) !important;
}
html[data-theme="dark"] .side-menu-bg,
html[data-theme="dark"] .scrollbar.side-menu-bg{
  background: rgba(8,8,8,.78) !important;
  border-color: var(--dg-border) !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.4) !important;
}
html[data-theme="dark"] .diagri-sidebar-resizer::before{
  background: linear-gradient(180deg, rgba(134,239,172,.16), rgba(45,212,191,.72), rgba(134,239,172,.16));
  box-shadow: 0 0 0 1px rgba(134,239,172,.14);
}
html[data-theme="dark"] .menu-title{
  color: var(--dg-muted) !important;
}
html[data-theme="dark"] .side-menu li a.menu-link,
html[data-theme="dark"] .side-menu li a{
  background: rgba(8,8,8,.88) !important;
  border-color: var(--dg-border) !important;
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .side-menu li a:hover{
  background: linear-gradient(135deg, rgba(34,197,94,.22), rgba(183,247,199,.12), rgba(8,8,8,.92)) !important;
  border-color: rgba(183,247,199,.35) !important;
  box-shadow: 0 14px 26px rgba(0,0,0,.35) !important;
}
html[data-theme="dark"] .side-menu li.active > a,
html[data-theme="dark"] .side-menu li > a.active{
  background: linear-gradient(135deg, rgba(34,197,94,.28), rgba(183,247,199,.16), rgba(8,8,8,.95)) !important;
  border-color: rgba(183,247,199,.45) !important;
  box-shadow: 0 18px 32px rgba(0,0,0,.45) !important;
}
html[data-theme="dark"] .icon-wrap{
  background: rgba(183,247,199,.08) !important;
  border-color: var(--dg-border) !important;
  color: var(--dg-muted) !important;
}
html[data-theme="dark"] .side-menu ul.collapse li a{
  background: rgba(8,8,8,.82) !important;
}
html[data-theme="dark"] .collapse-arrow{
  background: rgba(8,8,8,.82);
  border-color: var(--dg-border);
  color: var(--dg-muted);
}
html[data-theme="dark"] .card,
html[data-theme="dark"] .card-body,
html[data-theme="dark"] .modal-content,
html[data-theme="dark"] .dropdown-menu{
  background-color: var(--dg-surface) !important;
  color: var(--dg-ink) !important;
  border-color: var(--dg-border) !important;
}
html[data-theme="dark"] .modal-header,
html[data-theme="dark"] .modal-footer{
  border-color: var(--dg-border) !important;
}
html[data-theme="dark"] .dropdown-item{
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .dropdown-item:hover,
html[data-theme="dark"] .dropdown-item:focus{
  background-color: rgba(34,197,94,.12) !important;
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .form-control,
html[data-theme="dark"] .custom-select,
html[data-theme="dark"] .input-group-text{
  background-color: var(--dg-surface) !important;
  color: var(--dg-ink) !important;
  border-color: var(--dg-border) !important;
}
html[data-theme="dark"] .form-control::placeholder{
  color: var(--dg-muted) !important;
}
html[data-theme="dark"] .table{
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .table thead th{
  background-color: var(--dg-surface-2) !important;
  border-color: var(--dg-border) !important;
}
html[data-theme="dark"] .table td,
html[data-theme="dark"] .table th{
  border-color: var(--dg-border) !important;
}
html[data-theme="dark"] .table-hover tbody tr:hover{
  background-color: rgba(183,247,199,.08) !important;
}
html[data-theme="dark"] .page-title h4{
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .breadcrumb,
html[data-theme="dark"] .breadcrumb-item,
html[data-theme="dark"] .breadcrumb-item a{
  color: var(--dg-muted) !important;
}
html[data-theme="dark"] .topbar-btn,
html[data-theme="dark"] .topbar-pill,
html[data-theme="dark"] .topbar-user{
  background: rgba(8,8,8,.85) !important;
  border-color: var(--dg-border) !important;
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .diagri-toast{
  background: rgba(8,8,8,.92);
  border-color: rgba(183,247,199,.35);
  color: var(--dg-ink);
}

.topbar-theme-toggle{
  cursor: pointer;
}
.topbar-theme-toggle .theme-icon{
  width: 18px;
  height: 18px;
}
.topbar-theme-toggle .theme-icon-sun{
  display: none;
}
.topbar-theme-toggle .theme-icon-moon{
  display: inline-block;
}
html[data-theme="dark"] .topbar-theme-toggle .theme-icon-sun{
  display: inline-block;
}
html[data-theme="dark"] .topbar-theme-toggle .theme-icon-moon{
  display: none;
}

/* =========================
   SURFACES + COMPONENTS
========================= */
a{
  color: var(--dg-link);
}
a:hover{
  color: var(--dg-link-hover);
}

.content-wrapper h1,
.content-wrapper h2,
.content-wrapper h3,
.content-wrapper h4,
.content-wrapper h5,
.content-wrapper h6,
.card h1,
.card h2,
.card h3,
.card h4,
.card h5,
.card h6,
.modal-content h1,
.modal-content h2,
.modal-content h3,
.modal-content h4,
.modal-content h5,
.modal-content h6{
  color: var(--dg-ink) !important;
  font-family: "Cairo", "Poppins", sans-serif !important;
  font-weight: 800;
}

.content-wrapper p,
.content-wrapper li,
.content-wrapper td,
.content-wrapper th,
.content-wrapper legend,
.card p,
.card li,
.card td,
.card th,
.card legend,
.modal-content p,
.modal-content li,
.modal-content td,
.modal-content th,
.modal-content legend{
  color: var(--dg-ink);
}

.card-title{
  color: var(--dg-ink) !important;
  border-bottom-color: var(--dg-border) !important;
}

.text-muted,
.text-secondary,
.form-text,
small,
.small,
.diagri-help-text{
  color: var(--dg-subtle) !important;
}

.form-text,
.diagri-help-text{
  font-weight: 600;
  line-height: 1.6;
}

html[data-theme="dark"] .content-wrapper h1,
html[data-theme="dark"] .content-wrapper h2,
html[data-theme="dark"] .content-wrapper h3,
html[data-theme="dark"] .content-wrapper h4,
html[data-theme="dark"] .content-wrapper h5,
html[data-theme="dark"] .content-wrapper h6,
html[data-theme="dark"] .card h1,
html[data-theme="dark"] .card h2,
html[data-theme="dark"] .card h3,
html[data-theme="dark"] .card h4,
html[data-theme="dark"] .card h5,
html[data-theme="dark"] .card h6,
html[data-theme="dark"] .modal-content h1,
html[data-theme="dark"] .modal-content h2,
html[data-theme="dark"] .modal-content h3,
html[data-theme="dark"] .modal-content h4,
html[data-theme="dark"] .modal-content h5,
html[data-theme="dark"] .modal-content h6{
  color: var(--dg-ink) !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.12);
}

.page-title{
  margin-bottom: 18px;
  padding: 18px 22px;
  border-radius: 24px;
  border: 1px solid var(--dg-border);
  background:
    radial-gradient(200px 120px at 100% 0%, rgba(34,197,94,.08), transparent 70%),
    linear-gradient(135deg, rgba(255,255,255,.86), rgba(248,250,252,.92));
  box-shadow: var(--dg-shadow);
}
.page-title .row{
  align-items: center;
}
.page-title h4{
  font-weight: 950;
}
.page-title .breadcrumb{
  margin-bottom: 0;
  background: transparent;
}
html[data-theme="dark"] .page-title{
  background:
    radial-gradient(220px 140px at 100% 0%, rgba(34,197,94,.14), transparent 70%),
    linear-gradient(135deg, rgba(17,32,25,.96), rgba(11,23,17,.98));
}

.card,
.modal-content,
.dropdown-menu,
.list-group-item{
  background: var(--dg-surface) !important;
  color: var(--dg-ink) !important;
  border: 1px solid var(--dg-border) !important;
  box-shadow: var(--dg-shadow);
}
.card,
.modal-content{
  border-radius: 24px !important;
  overflow: hidden;
}
.card-header,
.card-footer,
.modal-header,
.modal-footer{
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,0)),
    var(--dg-surface-2) !important;
  border-color: var(--dg-border) !important;
  color: var(--dg-ink) !important;
}
.card-header,
.modal-header{
  padding: 1rem 1.25rem;
}
.card-footer,
.modal-footer{
  padding: .9rem 1.25rem;
}
.card-header h5,
.modal-title{
  margin-bottom: 0;
  font-weight: 900;
  color: var(--dg-ink);
}
.diagri-card-footer{
  background: transparent !important;
  border-top: 1px solid var(--dg-border) !important;
  padding-top: .9rem !important;
}

.diagri-footer{
  margin-top: 18px;
  border: 1px solid var(--dg-border);
  border-radius: 24px 24px 0 0;
  background:
    radial-gradient(220px 120px at 12% 0%, rgba(34,197,94,.10), transparent 70%),
    linear-gradient(180deg, var(--dg-footer), var(--dg-overlay));
  box-shadow: var(--dg-shadow);
  color: var(--dg-ink);
}

.btn,
.button{
  border-radius: 14px !important;
  font-weight: 800 !important;
  transition: transform .15s ease, box-shadow .2s ease, background-color .2s ease, border-color .2s ease, color .2s ease;
}
.btn:hover,
.button:hover{
  transform: translateY(-1px);
}
.btn:focus,
.btn.focus,
.button:focus,
.button.focus,
.form-control:focus,
.custom-select:focus,
.page-link:focus{
  box-shadow: 0 0 0 .2rem var(--dg-focus) !important;
}

.diagri-detail-link{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  font-weight: 800;
  color: var(--dg-link) !important;
}
.diagri-detail-link:hover{
  color: var(--dg-link-hover) !important;
  text-decoration: none;
}

.alert{
  border-radius: 18px;
  border: 1px solid var(--dg-border);
  background: var(--dg-surface-2);
  color: var(--dg-ink);
  box-shadow: var(--dg-shadow);
}
.alert-danger{
  background: linear-gradient(135deg, var(--dg-danger-soft), rgba(255,255,255,.02)) !important;
  border-color: rgba(220,38,38,.22) !important;
}
.alert-success{
  background: linear-gradient(135deg, var(--dg-success-soft), rgba(255,255,255,.02)) !important;
  border-color: rgba(22,163,74,.22) !important;
}
.alert-warning{
  background: linear-gradient(135deg, var(--dg-warning-soft), rgba(255,255,255,.02)) !important;
  border-color: rgba(245,158,11,.22) !important;
}
.alert-info{
  background: linear-gradient(135deg, var(--dg-info-soft), rgba(255,255,255,.02)) !important;
  border-color: rgba(13,148,136,.22) !important;
}

.badge{
  border-radius: 999px;
  padding: .5em .72em;
  font-weight: 800;
}
.badge-success{
  background: var(--dg-success-soft) !important;
  color: var(--dg-success) !important;
}
.badge-danger{
  background: var(--dg-danger-soft) !important;
  color: var(--dg-danger) !important;
}
.badge-warning{
  background: var(--dg-warning-soft) !important;
  color: var(--dg-warning) !important;
}
.badge-info{
  background: var(--dg-info-soft) !important;
  color: var(--dg-info) !important;
}
.badge-secondary{
  background: rgba(100,116,139,.14) !important;
  color: var(--dg-muted) !important;
}

.dropdown-menu{
  padding: .5rem;
  min-width: 12rem;
  border-radius: 18px !important;
}
.dropdown-item{
  border-radius: 12px;
  color: var(--dg-ink) !important;
  font-weight: 700;
  padding: .6rem .85rem;
}
.dropdown-item:hover,
.dropdown-item:focus{
  background-color: var(--dg-hover) !important;
  color: var(--dg-ink) !important;
}
.dropdown-divider{
  border-top-color: var(--dg-border) !important;
}

.close{
  color: var(--dg-ink);
  opacity: .72;
  text-shadow: none !important;
}
.close:hover{
  color: var(--dg-ink);
  opacity: 1;
}

.form-control,
.custom-select,
.input-group-text{
  border-radius: 14px;
  min-height: 46px;
  border: 1px solid var(--dg-input-border) !important;
  background: var(--dg-input-bg) !important;
  color: var(--dg-ink) !important;
  box-shadow: var(--dg-input-shadow) !important;
  transition: border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}
.diagri-bilingual-field,
.form-control,
textarea.form-control,
input.form-control{
  font-family: "Cairo", "Poppins", sans-serif !important;
  font-size: 1rem;
  line-height: 1.5;
  text-align: start;
  unicode-bidi: plaintext;
}
.form-control::placeholder{
  color: var(--dg-placeholder) !important;
  opacity: 1 !important;
}
.form-control:hover,
.custom-select:hover,
.dataTables_wrapper .dataTables_filter input:hover,
.dataTables_wrapper .dataTables_length select:hover{
  border-color: var(--dg-input-border-strong) !important;
}
.form-control:focus,
.custom-select:focus{
  border-color: var(--dg-input-border-strong) !important;
  background: var(--dg-input-bg) !important;
}
label,
.form-check-label{
  color: var(--dg-ink);
  font-weight: 700;
}
select option,
.custom-select option{
  color: #0f172a;
}
html[data-theme="dark"] select option,
html[data-theme="dark"] .custom-select option{
  background: #0f1b14;
  color: var(--dg-ink);
}

.table{
  color: var(--dg-ink);
  margin-bottom: 0;
}
.table thead th{
  background: var(--dg-surface-2);
  color: var(--dg-ink);
  border-color: var(--dg-border) !important;
  border-top: 0 !important;
  font-size: .79rem;
  font-weight: 900;
  letter-spacing: .02em;
}
.table td,
.table th{
  border-color: var(--dg-border) !important;
  vertical-align: middle;
}
.table-hover tbody tr{
  transition: background-color .18s ease;
}
.table-hover tbody tr:hover{
  background-color: var(--dg-hover) !important;
}
.table-info,
.table-info > th,
.table-info > td{
  background-color: var(--dg-info-soft) !important;
  color: var(--dg-ink) !important;
  border-color: var(--dg-border) !important;
}

.nav-tabs{
  gap: .35rem;
  border-bottom: 1px solid var(--dg-border);
}
.nav-tabs .nav-link{
  border: 1px solid transparent;
  border-radius: 16px 16px 0 0;
  color: var(--dg-muted);
  font-weight: 800;
  padding: .75rem 1rem;
}
.nav-tabs .nav-link:hover{
  background: var(--dg-hover);
  color: var(--dg-ink);
  border-color: transparent;
}
.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link{
  color: var(--dg-ink);
  background: var(--dg-surface);
  border-color: var(--dg-border) var(--dg-border) transparent;
  box-shadow: inset 0 1px 0 rgba(34,197,94,.18);
}

.pagination{
  gap: .35rem;
}
.page-link{
  min-width: 40px;
  border-radius: 12px !important;
  border-color: var(--dg-border) !important;
  background: var(--dg-surface);
  color: var(--dg-ink);
  text-align: center;
}
.page-link:hover{
  background: var(--dg-hover);
  color: var(--dg-link-hover);
}
.page-item.active .page-link{
  background: linear-gradient(135deg, var(--dg-g1), var(--dg-g3));
  border-color: transparent !important;
  color: #ffffff;
}
.page-item.disabled .page-link{
  background: var(--dg-surface-2);
  color: var(--dg-muted);
}

.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_processing{
  color: var(--dg-muted) !important;
  font-weight: 700;
}
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select{
  min-height: 40px;
  padding: .35rem .75rem;
  border: 1px solid var(--dg-input-border);
  border-radius: 12px;
  background: var(--dg-input-bg);
  color: var(--dg-ink);
  box-shadow: var(--dg-input-shadow);
}
.dataTables_wrapper .dataTables_paginate .paginate_button{
  padding: 0 !important;
  margin: 0 .15rem !important;
  border: 0 !important;
  background: transparent !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover{
  border: 0 !important;
  background: transparent !important;
}

.diagri-multiselect{
  position: relative;
  display: block;
}
.diagri-multiselect .dropdown-toggle{
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.diagri-multiselect .dropdown-menu{
  display: none;
  width: 100%;
  max-height: 220px;
  overflow-y: auto;
  inset: calc(100% + 8px) auto auto 0;
}
html[dir="rtl"] .diagri-multiselect .dropdown-menu{
  left: auto;
  right: 0;
}
.diagri-multiselect.open .dropdown-menu{
  display: block;
}
.diagri-multiselect .form-check{
  margin: .25rem 0;
  padding-inline-start: 1.7rem;
}
.diagri-multiselect .form-check-input{
  margin-top: .25rem;
}

.diagri-chat-panel{
  flex: 1;
  overflow-y: auto;
  max-height: 470px;
  padding: 1rem;
  border: 1px solid var(--dg-border);
  border-radius: 22px;
  background: var(--dg-chat-thread);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.diagri-chat-bubble{
  max-width: 78%;
  padding: .75rem .9rem;
  border: 1px solid var(--dg-border);
  border-radius: 18px;
  box-shadow: var(--dg-shadow);
}
.diagri-chat-bubble--support{
  background: var(--dg-chat-support);
  border-color: rgba(34,197,94,.22);
}
.diagri-chat-bubble--client{
  background: var(--dg-chat-client);
}
.diagri-chat-meta{
  color: var(--dg-muted);
}
.diagri-chat-message{
  white-space: pre-wrap;
  color: var(--dg-ink);
}

.diagri-empty-state{
  padding: 2rem;
  border: 1px dashed var(--dg-border);
  border-radius: 18px;
  background: var(--dg-surface-2);
  color: var(--dg-muted);
}
.diagri-chart-canvas{
  min-height: 300px;
  max-height: 320px;
}
.diagri-min-h-400{
  min-height: 400px;
}
.diagri-min-h-520{
  min-height: 520px;
}
.diagri-image-thumb{
  height: 48px;
  width: auto;
  padding: 2px;
  border-radius: 12px;
  border: 1px solid var(--dg-border);
  background: var(--dg-surface-2);
}
.diagri-cell-ellipsis{
  max-width: 300px;
  text-align: start;
}

html[data-theme="dark"] .btn-primary{
  background: linear-gradient(135deg, var(--dg-g1), var(--dg-g3)) !important;
  border-color: transparent !important;
  color: #04110a !important;
  box-shadow: 0 10px 24px rgba(34,197,94,.18);
}
html[data-theme="dark"] .btn-secondary{
  background: rgba(148,163,184,.16) !important;
  border-color: rgba(148,163,184,.28) !important;
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .btn-success{
  background: linear-gradient(135deg, rgba(34,197,94,.96), rgba(74,222,128,.86)) !important;
  border-color: transparent !important;
  color: #04110a !important;
}
html[data-theme="dark"] .btn-danger{
  background: linear-gradient(135deg, rgba(244,63,94,.92), rgba(251,113,133,.84)) !important;
  border-color: transparent !important;
  color: #ffffff !important;
}
html[data-theme="dark"] .btn-warning{
  background: linear-gradient(135deg, rgba(245,158,11,.92), rgba(251,191,36,.84)) !important;
  border-color: transparent !important;
  color: #111827 !important;
}
html[data-theme="dark"] .btn-info{
  background: linear-gradient(135deg, rgba(14,165,233,.9), rgba(103,232,249,.8)) !important;
  border-color: transparent !important;
  color: #082f49 !important;
}
html[data-theme="dark"] .btn-light{
  background: var(--dg-surface-2) !important;
  border-color: var(--dg-border) !important;
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .btn-outline-primary{
  color: var(--dg-link) !important;
  border-color: rgba(134,239,172,.36) !important;
  background: transparent !important;
}
html[data-theme="dark"] .btn-outline-primary:hover{
  background: rgba(134,239,172,.12) !important;
  color: var(--dg-link-hover) !important;
}
html[data-theme="dark"] .btn-outline-secondary{
  color: var(--dg-muted) !important;
  border-color: var(--dg-border-strong) !important;
}
html[data-theme="dark"] .btn-outline-secondary:hover{
  background: rgba(148,163,184,.12) !important;
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .btn-outline-success{
  color: var(--dg-success) !important;
  border-color: rgba(74,222,128,.38) !important;
}
html[data-theme="dark"] .btn-outline-success:hover{
  background: rgba(74,222,128,.12) !important;
}
html[data-theme="dark"] .btn-outline-danger{
  color: var(--dg-danger) !important;
  border-color: rgba(251,113,133,.38) !important;
}
html[data-theme="dark"] .btn-outline-danger:hover{
  background: rgba(251,113,133,.12) !important;
}
html[data-theme="dark"] .btn-outline-warning{
  color: var(--dg-warning) !important;
  border-color: rgba(251,191,36,.38) !important;
}
html[data-theme="dark"] .btn-outline-warning:hover{
  background: rgba(251,191,36,.12) !important;
}
html[data-theme="dark"] .btn-outline-info{
  color: var(--dg-info) !important;
  border-color: rgba(103,232,249,.38) !important;
}
html[data-theme="dark"] .btn-outline-info:hover{
  background: rgba(103,232,249,.12) !important;
}

html[data-theme="dark"] .bg-white{
  background-color: var(--dg-surface) !important;
}
html[data-theme="dark"] .text-dark{
  color: var(--dg-ink) !important;
}
html[data-theme="dark"] .text-muted{
  color: var(--dg-muted) !important;
}
html[data-theme="dark"] .text-danger{
  color: var(--dg-danger) !important;
}
html[data-theme="dark"] .text-warning{
  color: var(--dg-warning) !important;
}
html[data-theme="dark"] .text-success{
  color: var(--dg-success) !important;
}
html[data-theme="dark"] .text-info{
  color: var(--dg-info) !important;
}
html[data-theme="dark"] .border,
html[data-theme="dark"] .border-top,
html[data-theme="dark"] .border-right,
html[data-theme="dark"] .border-bottom,
html[data-theme="dark"] .border-left{
  border-color: var(--dg-border) !important;
}
html[data-theme="dark"] .modal-backdrop.show{
  opacity: .72;
}
