/* =====================================================================
   DuckDeals DMS — design system
   Brand: navy #000080 / ink #0E2A47  +  gold #F5B301 / #FFD24A
   Supports light/dark themes and LTR/RTL.
   ===================================================================== */
:root {
  --navy:#000080; --ink:#0E2A47; --ink-2:#13314f;
  --gold:#F5B301; --gold-2:#FFD24A; --amber:#E89F00;
  --brand:#1b3a8f;            /* accessible navy for accents on light */
  --brand-600:#15307a;

  --bg:#eef2f8; --surface:#ffffff; --surface-2:#f8fafc; --surface-3:#f1f5f9;
  --text:#0f172a; --muted:#64748b; --muted-2:#94a3b8;
  --border:#e2e8f0; --border-2:#cbd5e1;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow:0 4px 16px rgba(15,23,42,.08);
  --shadow-lg:0 16px 48px rgba(15,23,42,.16);
  --radius:14px; --radius-sm:10px; --radius-lg:20px;
  --sidebar-w:264px; --topbar-h:64px;

  --green:#16a34a; --green-bg:#dcfce7;
  --red:#dc2626;  --red-bg:#fee2e2;
  --amber-c:#d97706; --amber-bg:#fef3c7;
  --blue:#2563eb; --blue-bg:#dbeafe;
  --violet:#7c3aed; --violet-bg:#ede9fe;
  --slate:#475569; --slate-bg:#e2e8f0;

  --font:'Inter','Segoe UI',system-ui,-apple-system,'Helvetica Neue',Arial,'Noto Sans Arabic',sans-serif;
}
[data-theme="dark"]{
  --bg:#0b1220; --surface:#111a2e; --surface-2:#0f1830; --surface-3:#1a2542;
  --text:#e8eefb; --muted:#9fb0cc; --muted-2:#6b7d9c;
  --border:#22304f; --border-2:#2c3c61;
  --brand:#7aa2ff; --brand-600:#9bb8ff;
  --shadow:0 6px 24px rgba(0,0,0,.4); --shadow-lg:0 20px 60px rgba(0,0,0,.55); --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --green-bg:#0c2c1c;--red-bg:#3a1414;--amber-bg:#3a2a09;--blue-bg:#0e1f44;--violet-bg:#241844;--slate-bg:#1c2840;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14.5px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
svg.icon{display:inline-block;vertical-align:middle;flex:0 0 auto}
img{max-width:100%}
h1,h2,h3,h4{margin:0 0 .4em;font-weight:700;letter-spacing:-.01em;color:var(--text)}
h1{font-size:1.55rem} h2{font-size:1.2rem} h3{font-size:1.02rem}
:focus-visible{outline:3px solid color-mix(in srgb,var(--gold) 70%,transparent);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ---------- Layout ---------- */
.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar-backdrop{display:none}            /* never a grid item on desktop */
.sidebar{grid-column:1;grid-row:1}
.main{grid-column:2;grid-row:1}
.sidebar{background:linear-gradient(180deg,var(--navy),var(--ink));color:#dbe6ff;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;overflow:hidden;z-index:40}
.sidebar__brand{display:flex;align-items:center;gap:10px;padding:16px 18px;font-weight:800;color:#fff;font-size:1.12rem;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar__brand .logo{width:38px;height:38px;flex:0 0 auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}
.sidebar__brand small{display:block;font-size:.62rem;font-weight:600;letter-spacing:.14em;color:var(--gold-2);text-transform:uppercase}
.nav{flex:1;overflow-y:auto;padding:10px 10px 30px;scrollbar-width:thin}
.nav::-webkit-scrollbar{width:6px}.nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:3px}
.nav__section{padding:14px 12px 6px;font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#7e93c4}
.nav__item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:#c7d4f0;font-weight:600;margin:1px 0;position:relative;transition:.15s}
.nav__item:hover{background:rgba(255,255,255,.08);color:#fff;text-decoration:none}
.nav__item.active{background:rgba(255,255,255,.12);color:#fff}
.nav__item.active::before{content:"";position:absolute;inset-inline-start:-10px;top:8px;bottom:8px;width:4px;border-radius:0 4px 4px 0;background:linear-gradient(var(--gold-2),var(--gold))}
.nav__item .badge-count{margin-inline-start:auto;background:var(--gold);color:var(--ink);font-size:.68rem;font-weight:800;padding:1px 7px;border-radius:20px}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 20px;position:sticky;top:0;z-index:30}
.topbar__search{flex:1;max-width:520px;position:relative}
.topbar__search input{width:100%;padding:9px 14px 9px 40px;border:1px solid var(--border);background:var(--surface-2);border-radius:30px;color:var(--text);font-size:14px}
.topbar__search .icon{position:absolute;inset-inline-start:13px;top:50%;transform:translateY(-50%);color:var(--muted)}
.topbar__spacer{flex:1}
.iconbtn{position:relative;width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.iconbtn:hover{background:var(--surface-3);border-color:var(--border-2)}
.iconbtn .dot{position:absolute;top:7px;inset-inline-end:7px;min-width:16px;height:16px;padding:0 3px;border-radius:10px;background:var(--red);color:#fff;font-size:.62rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}
.content{padding:24px;max-width:1500px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.page-head .grow{flex:1;min-width:200px}
.page-head h1{margin:0}
.page-head .sub{color:var(--muted);font-size:.9rem;margin-top:2px}
.breadcrumbs{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:.82rem;color:var(--muted);margin-bottom:12px}
.breadcrumbs a{color:var(--muted)}.breadcrumbs .sep{opacity:.5}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:10px;border:1px solid transparent;font-weight:700;font-size:.9rem;cursor:pointer;transition:.15s;white-space:nowrap;line-height:1.2}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:none}
.btn-primary{background:var(--navy);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:#0a0a9c}
.btn-gold{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--ink);box-shadow:0 4px 14px rgba(245,179,1,.35)}
.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text)}
.btn-ghost:hover{background:var(--surface-3)}
.btn-danger{background:var(--red);color:#fff}
.btn-success{background:var(--green);color:#fff}
.btn-sm{padding:6px 11px;font-size:.82rem;border-radius:8px}
.btn-lg{padding:12px 22px;font-size:1rem}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn-block{width:100%;justify-content:center}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card__head{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--border)}
.card__head h3{margin:0;flex:1}
.card__body{padding:18px}
.card__foot{padding:14px 18px;border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 var(--radius) var(--radius)}

.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-auto{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}

/* Stat cards */
.stat{display:flex;gap:14px;align-items:center;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:.18s}
.stat:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.stat__icon{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;color:#fff}
.stat__num{font-size:1.7rem;font-weight:800;line-height:1;letter-spacing:-.02em}
.stat__label{color:var(--muted);font-size:.82rem;font-weight:600;margin-top:4px}
.stat__trend{font-size:.74rem;font-weight:700;margin-top:3px}
.bg-navy{background:linear-gradient(135deg,#1b3a8f,#000080)}
.bg-gold{background:linear-gradient(135deg,var(--gold-2),var(--amber));color:var(--ink)!important}
.bg-green{background:linear-gradient(135deg,#22c55e,#15803d)}
.bg-red{background:linear-gradient(135deg,#f87171,#dc2626)}
.bg-violet{background:linear-gradient(135deg,#a78bfa,#7c3aed)}
.bg-blue{background:linear-gradient(135deg,#60a5fa,#2563eb)}
.bg-slate{background:linear-gradient(135deg,#94a3b8,#475569)}
.bg-amber{background:linear-gradient(135deg,#fbbf24,#d97706)}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:30px;font-size:.74rem;font-weight:700;line-height:1.4;white-space:nowrap}
.badge .icon{margin-inline-start:-2px}
.badge-green{background:var(--green-bg);color:var(--green)}
.badge-red{background:var(--red-bg);color:var(--red)}
.badge-amber{background:var(--amber-bg);color:var(--amber-c)}
.badge-blue{background:var(--blue-bg);color:var(--blue)}
.badge-violet{background:var(--violet-bg);color:var(--violet)}
.badge-slate{background:var(--slate-bg);color:var(--slate)}
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:8px;font-size:.74rem;font-weight:600;background:var(--surface-3);color:var(--text);border:1px solid var(--border)}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}
table.tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.tbl thead th{text-align:start;padding:12px 14px;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:var(--surface-2);border-bottom:1px solid var(--border);font-weight:700;white-space:nowrap;position:sticky;top:0}
.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:.12s}
.tbl tbody tr:hover{background:var(--surface-2)}
.tbl .doc-title{font-weight:700;color:var(--text)}
.tbl .muted{color:var(--muted);font-size:.82rem}
.tbl .row-icon{display:flex;align-items:center;gap:10px}
.tbl .row-icon .ficon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--surface-3);flex:0 0 auto}

/* ---------- Forms ---------- */
.form-row{margin-bottom:16px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
label.lbl{display:block;font-weight:700;font-size:.82rem;margin-bottom:6px;color:var(--text)}
label.lbl .req{color:var(--red)}
.inp,select.inp,textarea.inp{width:100%;padding:10px 13px;border:1px solid var(--border);background:var(--surface);border-radius:10px;color:var(--text);font-size:.92rem;font-family:inherit;transition:.15s}
.inp:focus,select.inp:focus,textarea.inp:focus{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 18%,transparent);outline:none}
textarea.inp{min-height:96px;resize:vertical}
.inp.err{border-color:var(--red)}
.field-err{color:var(--red);font-size:.78rem;margin-top:5px;font-weight:600}
.hint{color:var(--muted);font-size:.78rem;margin-top:5px}
.inp-group{display:flex;align-items:center;gap:8px}
.dropzone{border:2px dashed var(--border-2);border-radius:var(--radius);padding:26px;text-align:center;background:var(--surface-2);cursor:pointer;transition:.15s}
.dropzone:hover,.dropzone.drag{border-color:var(--gold);background:color-mix(in srgb,var(--gold) 8%,var(--surface-2))}
.switch{position:relative;display:inline-block;width:42px;height:24px}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;cursor:pointer;inset:0;background:var(--border-2);border-radius:24px;transition:.2s}
.switch .sl::before{content:"";position:absolute;height:18px;width:18px;inset-inline-start:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked+.sl{background:var(--green)}
.switch input:checked+.sl::before{transform:translateX(18px)}
[dir=rtl] .switch input:checked+.sl::before{transform:translateX(-18px)}

/* ---------- Dropdown menu ---------- */
.dd{position:relative}
.dd__menu{position:absolute;inset-inline-end:0;top:calc(100% + 8px);background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);min-width:210px;padding:6px;z-index:50;display:none}
.dd__menu.open{display:block;animation:pop .14s ease}
@keyframes pop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.dd__item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:8px;color:var(--text);font-weight:600;font-size:.86rem;cursor:pointer;width:100%;background:none;border:none;text-align:start}
.dd__item:hover{background:var(--surface-3);text-decoration:none}
.dd__item.danger{color:var(--red)}
.dd__sep{height:1px;background:var(--border);margin:5px 0}

/* ---------- Modal ---------- */
.modal-backdrop{position:fixed;inset:0;background:rgba(8,15,30,.55);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:100;opacity:0;transition:.2s}
.modal-backdrop.open{opacity:1}
.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:620px;max-height:90vh;overflow:auto;transform:translateY(-12px);transition:.2s}
.modal-backdrop.open .modal{transform:none}
.modal__head{display:flex;align-items:center;gap:10px;padding:18px 22px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:2}
.modal__head h3{flex:1;margin:0}
.modal__body{padding:22px}
.modal__foot{padding:16px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;background:var(--surface-2);position:sticky;bottom:0}
.modal-lg{max-width:880px}.modal-sm{max-width:440px}

/* ---------- Toasts ---------- */
#toasts{position:fixed;top:18px;inset-inline-end:18px;z-index:200;display:flex;flex-direction:column;gap:10px;max-width:min(360px,calc(100vw - 32px))}
.toast{display:flex;gap:11px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-inline-start:4px solid var(--slate);border-radius:12px;padding:13px 15px;box-shadow:var(--shadow-lg);animation:slidein .25s ease}
.toast.success{border-inline-start-color:var(--green)} .toast.error{border-inline-start-color:var(--red)}
.toast.warning{border-inline-start-color:var(--amber-c)} .toast.info{border-inline-start-color:var(--blue)}
.toast .t-title{font-weight:700;font-size:.88rem}.toast .t-msg{color:var(--muted);font-size:.82rem;margin-top:2px}
@keyframes slidein{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}

/* ---------- Tree ---------- */
.tree{font-size:.9rem}
.tree__node{user-select:none}
.tree__row{display:flex;align-items:center;gap:7px;padding:6px 8px;border-radius:8px;cursor:pointer}
.tree__row:hover{background:var(--surface-3)}
.tree__row.sel{background:color-mix(in srgb,var(--brand) 14%,transparent);font-weight:700}
.tree__toggle{width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.15s}
.tree__toggle.open{transform:rotate(90deg)}
[dir=rtl] .tree__toggle{transform:scaleX(-1)}[dir=rtl] .tree__toggle.open{transform:rotate(90deg)}
.tree__children{margin-inline-start:18px;border-inline-start:1px dashed var(--border-2);padding-inline-start:6px;display:none}
.tree__children.open{display:block}
.tree__count{margin-inline-start:auto;font-size:.7rem;color:var(--muted);background:var(--surface-3);padding:0 7px;border-radius:10px}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:18px;overflow-x:auto}
.tab{padding:10px 16px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}
.tab.active{color:var(--brand);border-bottom-color:var(--gold)}

/* ---------- Timeline ---------- */
.timeline{position:relative;padding-inline-start:26px}
.timeline::before{content:"";position:absolute;inset-inline-start:9px;top:4px;bottom:4px;width:2px;background:var(--border)}
.tl-item{position:relative;padding:0 0 18px}
.tl-dot{position:absolute;inset-inline-start:-26px;top:1px;width:20px;height:20px;border-radius:50%;background:var(--surface);border:2px solid var(--brand);display:flex;align-items:center;justify-content:center;color:var(--brand)}
.tl-item.approve .tl-dot{border-color:var(--green);color:var(--green)}
.tl-item.reject .tl-dot{border-color:var(--red);color:var(--red)}
.tl-item .tl-meta{font-size:.78rem;color:var(--muted)}

/* ---------- Pagination ---------- */
.pager{display:flex;gap:6px;align-items:center;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}
.pager a,.pager span{padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface);font-weight:600;font-size:.84rem;color:var(--text)}
.pager .cur{background:var(--navy);color:#fff;border-color:var(--navy)}
.pager .disabled{opacity:.45;pointer-events:none}

/* ---------- Misc ---------- */
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--gold-2),var(--amber));color:var(--ink);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.82rem;flex:0 0 auto}
.avatar-sm{width:30px;height:30px;font-size:.72rem}
.empty{text-align:center;padding:50px 20px;color:var(--muted)}
.empty .icon{color:var(--muted-2);margin-bottom:10px}
.empty h3{color:var(--text)}
.skeleton{background:linear-gradient(90deg,var(--surface-3) 25%,var(--surface-2) 50%,var(--surface-3) 75%);background-size:200% 100%;animation:sk 1.3s infinite;border-radius:8px}
@keyframes sk{to{background-position:-200% 0}}
.progress{height:8px;background:var(--surface-3);border-radius:10px;overflow:hidden}
.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--gold-2),var(--gold))}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.toolbar .grow{flex:1}
.divider{height:1px;background:var(--border);margin:18px 0}
.kv{display:grid;grid-template-columns:150px 1fr;gap:8px 14px;font-size:.9rem}
.kv dt{color:var(--muted);font-weight:600}
.kv dd{margin:0;font-weight:600}
.muted{color:var(--muted)}
.text-end{text-align:end}.text-center{text-align:center}
.flex{display:flex}.items-center{align-items:center}.gap{gap:10px}.gap-sm{gap:6px}.wrap{flex-wrap:wrap}
.mt{margin-top:16px}.mb{margin-bottom:16px}.mt-sm{margin-top:8px}
.hide{display:none!important}
.nowrap{white-space:nowrap}
.scan-box{display:inline-flex;flex-direction:column;align-items:center;gap:6px;padding:12px;background:#fff;border:1px solid var(--border);border-radius:12px;max-width:100%}
.scan-box canvas,.scan-box svg,.scan-box img{display:block;max-width:100%;height:auto}

/* ---------- Auth pages ---------- */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.auth-hero{background:linear-gradient(150deg,var(--navy),var(--ink));color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.auth-hero::after{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(245,179,1,.22),transparent 70%);bottom:-160px;inset-inline-end:-120px}
.auth-hero h1{color:#fff;font-size:2.1rem;max-width:440px;line-height:1.2}
.auth-hero p{color:#bcd0ff;max-width:420px}
.auth-hero .feat{display:flex;align-items:center;gap:12px;margin:14px 0;color:#e6eeff;font-weight:600}
.auth-hero .feat .ic{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:var(--gold-2)}
.auth-card{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}
.auth-box{width:100%;max-width:400px}
.auth-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.3rem;margin-bottom:6px}

/* ---------- Responsive ---------- */
.menu-toggle{display:none}
@media (max-width:1024px){
  :root{--sidebar-w:0px}
  .app-shell{grid-template-columns:1fr}
  .main{grid-column:1;grid-row:auto}      /* single column on mobile */
  .sidebar{position:fixed;inset-inline-start:0;top:0;width:280px;transform:translateX(-100%);transition:.25s;box-shadow:var(--shadow-lg)}
  [dir=rtl] .sidebar{transform:translateX(100%)}
  .sidebar.open{transform:none}
  .menu-toggle{display:inline-flex}
  .sidebar-backdrop{position:fixed;inset:0;background:rgba(8,15,30,.5);z-index:35;display:none}
  .sidebar-backdrop.open{display:block}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr}
  .auth-wrap{grid-template-columns:1fr}.auth-hero{display:none}
}
@media (max-width:640px){
  .content{padding:16px}
  .form-grid{grid-template-columns:1fr}
  .grid-2,.grid-4{grid-template-columns:1fr}
  .topbar__search{display:none}
  /* Dialogs and inline-sized filter controls must fit a phone viewport */
  .modal{max-width:95vw}
  .inp[style*="max-width"]{max-width:100%!important;width:100%}
  /* responsive table → cards */
  .tbl.responsive thead{display:none}
  .tbl.responsive tbody tr{display:block;border:1px solid var(--border);border-radius:12px;margin-bottom:12px;padding:6px 4px;background:var(--surface)}
  .tbl.responsive tbody td{display:flex;justify-content:space-between;gap:12px;border:none;padding:8px 14px}
  .tbl.responsive tbody td::before{content:attr(data-label);font-weight:700;color:var(--muted);font-size:.74rem;text-transform:uppercase}
  .tbl.responsive tbody td.no-label::before{content:""}
}

/* ---------- Print (labels) ---------- */
@media print{
  .sidebar,.topbar,.no-print{display:none!important}
  .app-shell{display:block}.content{padding:0}
  body{background:#fff}
  .print-label{page-break-inside:avoid}
  .dms-ac__menu,.ts-dropdown{display:none!important}
}

/* ---------- Searchable selects (Tom Select) themed to design tokens ---------- */
.ts-wrapper{width:100%}
.ts-control,.ts-wrapper.single .ts-control{border:1px solid var(--border);background:var(--surface);border-radius:10px;color:var(--text);min-height:42px;padding:7px 12px;font-size:.92rem;box-shadow:none;transition:.15s}
.ts-wrapper.focus .ts-control{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 18%,transparent)}
.ts-control,.ts-control input{color:var(--text)!important}
.ts-control input::placeholder{color:var(--muted);opacity:1}
.ts-wrapper.single .ts-control:after{border-color:var(--muted) transparent transparent;margin-top:-2px}
.ts-wrapper.single.dropdown-active .ts-control:after{border-color:transparent transparent var(--muted)}
.ts-wrapper.disabled .ts-control{opacity:.55;cursor:not-allowed}
.ts-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-lg);color:var(--text);margin-top:5px;z-index:99999;overflow:hidden}
.ts-dropdown .ts-dropdown-content{max-height:300px}
.ts-dropdown .option{padding:9px 13px;color:var(--text);border-radius:7px;margin:1px 4px}
.ts-dropdown .option:hover{background:color-mix(in srgb,var(--brand) 9%,transparent)}
.ts-dropdown .active{background:color-mix(in srgb,var(--brand) 16%,transparent);color:var(--text)}
.ts-dropdown .optgroup-header{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;font-weight:800;background:transparent}
.ts-dropdown .no-results{padding:10px 13px;color:var(--muted);font-size:.86rem}
.ts-control .item{background:color-mix(in srgb,var(--brand) 15%,transparent);color:var(--text);border:1px solid color-mix(in srgb,var(--brand) 25%,transparent);border-radius:7px;padding:1px 8px}
.ts-control .item .remove{border-inline-start:1px solid color-mix(in srgb,var(--brand) 25%,transparent);color:var(--muted)}
.ts-control .item .remove:hover{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red)}
.inp.err+.ts-wrapper .ts-control,.ts-wrapper.err .ts-control{border-color:var(--red)}

/* ---------- Typeahead DB-lookup menu ---------- */
.dms-ac__menu{position:fixed;z-index:100000;display:none;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-lg);max-height:290px;overflow:auto;min-width:180px;padding:5px}
.dms-ac__menu.open{display:block;animation:fadein .12s ease}
.dms-ac__item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 11px;border-radius:7px;cursor:pointer;font-size:.9rem;color:var(--text)}
.dms-ac__item.active,.dms-ac__item:hover{background:color-mix(in srgb,var(--brand) 12%,transparent)}
.dms-ac__meta{color:var(--muted);font-size:.76rem;font-weight:700;white-space:nowrap}

/* ---------- System Health ---------- */
.health-hero{display:flex;align-items:center;gap:18px;padding:20px 22px;border-radius:14px;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow)}
.health-hero__icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;flex:none}
.health-hero--green .health-hero__icon{background:linear-gradient(135deg,#16a34a,#15803d)}
.health-hero--amber .health-hero__icon{background:linear-gradient(135deg,#f59e0b,#d97706)}
.health-hero--red .health-hero__icon{background:linear-gradient(135deg,#ef4444,#dc2626)}
.health-hero--green{border-color:color-mix(in srgb,#16a34a 35%,var(--border))}
.health-hero--amber{border-color:color-mix(in srgb,#f59e0b 35%,var(--border))}
.health-hero--red{border-color:color-mix(in srgb,#ef4444 35%,var(--border))}
.health-hero__title{font-size:1.25rem;font-weight:800}
.health-hero__sub{color:var(--muted);font-size:.86rem;margin-top:2px}
.health-hero__counts{display:flex;gap:10px}
.hc{display:flex;flex-direction:column;align-items:center;min-width:58px;padding:8px 6px;border-radius:10px;background:var(--surface-3);font-size:.66rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:800}
.hc span{font-size:1.3rem;font-weight:800;color:var(--text)}
.hc-red span{color:var(--red)}.hc-amber span{color:var(--amber)}.hc-green span{color:var(--green)}
.hrows{display:flex;flex-direction:column}
.hrow{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:10px 2px;border-bottom:1px solid var(--border)}
.hrow:last-child{border-bottom:0}
.hrow__l{display:flex;flex-direction:column;gap:2px;min-width:0}
.hrow__label{font-weight:700;font-size:.9rem}
.hrow__hint{font-size:.76rem;color:var(--muted)}
.hrow__r{display:flex;align-items:center;gap:8px;flex:none;text-align:end}
.hrow__val{font-size:.86rem;color:var(--text);font-weight:600;word-break:break-word;max-width:230px}
.logbox{background:#0b1220;color:#e2e8f0;border-radius:10px;padding:14px;font-size:.77rem;line-height:1.5;overflow:auto;max-height:280px;white-space:pre-wrap;word-break:break-word}

/* ---------- Documentation / User Guide ---------- */
.doc{display:grid;grid-template-columns:262px 1fr;gap:26px;align-items:start}
.doc-toc{position:sticky;top:78px;max-height:calc(100vh - 98px);overflow:auto;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:12px}
.doc-toc__search{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:9px;margin-bottom:8px;color:var(--muted)}
.doc-toc__search input{border:0;background:transparent;outline:none;color:var(--text);width:100%;font-size:.86rem}
.doc-toc__nav{display:flex;flex-direction:column}
.doc-toc__nav a{padding:7px 10px;border-radius:8px;color:var(--muted);font-size:.83rem;font-weight:600;text-decoration:none;border-inline-start:2px solid transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-toc__nav a:hover{background:color-mix(in srgb,var(--brand) 7%,transparent);color:var(--text)}
.doc-toc__nav a.active{background:color-mix(in srgb,var(--brand) 12%,transparent);color:var(--brand);border-inline-start-color:var(--brand)}
.doc-body{min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:8px 30px 30px}
.doc-hero{display:flex;gap:16px;align-items:center;padding:22px 4px 18px;border-bottom:1px solid var(--border);margin-bottom:6px}
.doc-hero__badge{width:58px;height:58px;border-radius:15px;background:linear-gradient(135deg,var(--gold),var(--gold-2));display:flex;align-items:center;justify-content:center;color:var(--ink);flex:none}
.doc-sec{padding:22px 0;border-bottom:1px solid var(--border);scroll-margin-top:80px}
.doc-sec:last-of-type{border-bottom:0}
.doc-sec h2{font-size:1.3rem;font-weight:800;margin:0 0 12px;padding-bottom:7px;border-bottom:2px solid color-mix(in srgb,var(--gold) 60%,transparent);display:inline-block}
.doc-sec h3{font-size:1.02rem;font-weight:800;margin:18px 0 8px}
.doc-sec h4{font-size:.92rem;font-weight:800;margin:14px 0 6px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.doc-sec p{line-height:1.72;margin:8px 0}
.doc-sec ul,.doc-sec ol{line-height:1.7;padding-inline-start:22px;margin:8px 0}
.doc-sec li{margin:5px 0}
.doc-steps{counter-reset:step;list-style:none;padding-inline-start:0}
.doc-steps li{position:relative;padding-inline-start:40px;margin:11px 0;line-height:1.6}
.doc-steps li::before{counter-increment:step;content:counter(step);position:absolute;inset-inline-start:0;top:-2px;width:27px;height:27px;border-radius:50%;background:var(--brand);color:#fff;font-weight:800;font-size:.8rem;display:flex;align-items:center;justify-content:center}
.callout{display:block;padding:12px 14px;border-radius:10px;margin:14px 0;font-size:.9rem;line-height:1.65;border-inline-start:4px solid var(--brand);background:color-mix(in srgb,var(--brand) 6%,transparent)}
.callout-tip{border-color:var(--green);background:color-mix(in srgb,var(--green) 9%,transparent)}
.callout-warn{border-color:var(--amber);background:color-mix(in srgb,var(--amber) 11%,transparent)}
.callout-info{border-color:var(--brand);background:color-mix(in srgb,var(--brand) 7%,transparent)}
.callout-note{border-color:var(--muted);background:var(--surface-3)}
.doc-table{width:100%;border-collapse:collapse;margin:14px 0;font-size:.85rem}
.doc-table th,.doc-table td{border:1px solid var(--border);padding:8px 11px;text-align:start;vertical-align:top}
.doc-table th{background:var(--surface-3);font-weight:800}
.kbd{display:inline-block;padding:1px 7px;border:1px solid var(--border);border-bottom-width:2px;border-radius:6px;background:var(--surface-3);font-family:monospace;font-size:.8rem;font-weight:700}
.doc-foot{padding-top:18px;margin-top:8px;border-top:1px solid var(--border);font-size:.8rem}
@media (max-width:980px){
  .doc{grid-template-columns:1fr}
  .doc-toc{position:static;max-height:none;order:-1}
  .doc-body{padding:8px 18px 24px}
  .health-hero__counts{display:none}
  .hrow__val{max-width:150px}
}

/* ---------- Branding logo / favicon manager ---------- */
.brand-asset{display:flex;gap:16px;align-items:flex-start;padding:4px 0}
.brand-asset__preview{width:76px;height:76px;border:1px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);overflow:hidden;flex:none;padding:8px}
.brand-asset__preview img{max-width:100%;max-height:100%;object-fit:contain}

/* ---------- Classic single search box + collapsible filters ---------- */
[hidden]{display:none!important}   /* author display rules must not override the hidden attribute */
.search-box{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:4px 8px 4px 14px;box-shadow:var(--shadow)}
.search-box:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 16%,transparent)}
.search-box__icon{color:var(--muted);display:flex;flex:none}
.search-box__input{flex:1;border:0;background:transparent;outline:none;color:var(--text);font-size:1rem;padding:11px 2px;min-width:0;font-family:inherit}
.search-box__input::placeholder{color:var(--muted)}
.iconbtn-sm{width:32px;height:32px;flex:none}
.adv-filters{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start;padding:16px}
.adv-filters .form-row{margin:0;min-width:175px}
.adv-filters .form-row .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin-bottom:5px}
.mb-sm{margin-bottom:10px}
.badge-navy{background:color-mix(in srgb,var(--brand) 15%,transparent);color:var(--brand)}
@media (max-width:640px){ .adv-filters .form-row{min-width:100%} }
/* Collapse any inline two-column "sidebar" grid (dashboard, profile, users, documents,
   workflows use class="grid" style="grid-template-columns:…") to a single column so
   fixed-px side panels never overflow a tablet/phone viewport. */
@media (max-width:820px){ .grid[style*="grid-template-columns"]{grid-template-columns:1fr!important} }

/* ---- Utilities + SSO / import ---- */
.justify-end{justify-content:flex-end}
.items-end{align-items:flex-end}
.inp-sm{padding:5px 8px;font-size:.85rem;height:auto}
.empty-row{text-align:center;color:var(--muted);padding:34px 10px}
.empty-row svg{opacity:.4;margin-bottom:6px}
/* Microsoft sign-in button + divider on the login page */
.sso-divider{display:flex;align-items:center;text-align:center;color:var(--muted);font-size:.8rem;margin:16px 0}
.sso-divider::before,.sso-divider::after{content:"";flex:1;height:1px;background:var(--border)}
.sso-divider span{padding:0 12px;text-transform:uppercase;letter-spacing:.08em}
.btn-microsoft{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#3b3b3b;border:1px solid #d0d0d0;font-weight:700}
.btn-microsoft:hover{background:#f7f7f7;border-color:#bdbdbd}
[data-theme=dark] .btn-microsoft{background:#2b2b2b;color:#eee;border-color:#444}
[data-theme=dark] .btn-microsoft:hover{background:#333}
/* Settings switch rows */
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 0}
.switch-row span small{display:block;margin-top:2px}
/* Copy-to-clipboard field */
.copy-field{display:flex;gap:8px;align-items:stretch}
.copy-field .inp{flex:1;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.82rem}
/* Diagnostic check rows */
.check-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.check-row:last-child{border-bottom:0}
.check-ic{display:flex;flex-shrink:0}
/* Numbered setup steps */
.steps{margin:0 0 16px;padding-inline-start:20px;line-height:1.7;font-size:.9rem}
.steps li{margin-bottom:6px}
.steps code{background:var(--surface-2);padding:1px 6px;border-radius:5px;font-size:.85em}
/* Key/value table (diagnostic) */
.tbl-kv th{width:170px;color:var(--muted);font-weight:600;text-align:start;white-space:nowrap}
.tbl-kv code{word-break:break-all}
