/* =====================================================================
   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}
/* Backdrop is a grid child — keep it out of the grid on desktop so it never
   becomes a phantom column that pushes .main below the sidebar. */
.sidebar-backdrop{display:none}
.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;grid-column:1}
.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;grid-column:2}
.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:360px}
.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}
.scan-box canvas,.scan-box svg{display:block}

/* ---------- 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}
  .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}
  /* 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}
}

/* ---------- Searchable select (combobox) ---------- */
.combo{position:relative}
.combo__control{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.combo__value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.combo__value.is-placeholder{color:var(--muted)}
.combo__chev{color:var(--muted);font-size:.8rem;transition:.15s}
.combo.open .combo__chev{transform:rotate(180deg)}
.combo.open .combo__control{border-color:var(--brand);box-shadow:0 0 0 3px color-mix(in srgb,var(--brand) 18%,transparent)}
.combo__pop{position:absolute;inset-inline-start:0;inset-inline-end:0;top:calc(100% + 5px);background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-lg);z-index:60;display:none;overflow:hidden;animation:pop .14s ease}
.combo.open .combo__pop{display:block}
.combo__search{margin:8px;width:calc(100% - 16px);padding:8px 11px;border:1px solid var(--border);border-radius:8px;font-size:.88rem}
.combo__list{max-height:240px;overflow-y:auto;padding:4px}
.combo__opt{padding:9px 11px;border-radius:8px;cursor:pointer;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.combo__opt:hover,.combo__opt.hi{background:var(--surface-3)}
.combo__opt.sel{background:color-mix(in srgb,var(--brand) 14%,transparent);font-weight:700}
.combo__empty{padding:14px;text-align:center;color:var(--muted);font-size:.84rem}

/* ---------- Saudi plate ---------- */
.ksa-plate{display:block;max-width:100%;height:auto;filter:drop-shadow(0 2px 6px rgba(15,23,42,.15))}
.plate-chip{display:inline-flex;flex-direction:column;align-items:center;gap:1px;padding:4px 10px;border:2px solid var(--border-2);border-radius:8px;background:#fff;line-height:1.15;min-width:96px}
.plate-chip__lat{font-weight:800;color:#0E2A47;font-size:.82rem;letter-spacing:1px}
.plate-chip__ar{font-size:.8rem;color:#0E2A47;direction:rtl}

/* ---------- User manual / documentation ---------- */
.doc-layout{display:grid;grid-template-columns:248px 1fr;gap:26px;align-items:start}
.doc-toc{position:sticky;top:calc(var(--topbar-h) + 18px);max-height:calc(100vh - var(--topbar-h) - 34px);overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px;scrollbar-width:thin}
.doc-toc__search{display:flex;align-items:center;gap:7px;padding:7px 10px;border:1px solid var(--border);border-radius:9px;margin-bottom:8px;color:var(--muted)}
.doc-toc__search input{border:none;background:none;outline:none;width:100%;color:var(--text);font-size:.85rem}
.doc-toc nav a{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;color:var(--muted);font-weight:600;font-size:.83rem;line-height:1.25}
.doc-toc nav a:hover{background:var(--surface-3);color:var(--text);text-decoration:none}
.doc-toc nav a.active{background:color-mix(in srgb,var(--brand) 14%,transparent);color:var(--brand)}
.doc-content{min-width:0}
.doc-hero{background:linear-gradient(135deg,var(--navy),var(--ink));color:#fff;border-radius:var(--radius-lg);padding:26px 28px;margin-bottom:24px}
.doc-hero h2{color:#fff;margin:8px 0 6px;font-size:1.4rem}
.doc-hero p{color:#cfe;max-width:680px;margin:0;color:#bcd0ff}
.doc-hero__badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);color:var(--gold-2);font-weight:700;font-size:.72rem;padding:4px 10px;border-radius:20px}
.doc-section{scroll-margin-top:calc(var(--topbar-h) + 18px);margin-bottom:34px}
.doc-section>h2{display:flex;align-items:center;gap:10px;font-size:1.3rem;padding-bottom:9px;border-bottom:2px solid var(--border);margin-bottom:14px}
.doc-section h3{font-size:1.04rem;margin:22px 0 8px;color:var(--text)}
.doc-section h4{font-size:.92rem;margin:16px 0 6px}
.doc-section p{line-height:1.72;margin:0 0 12px}
.doc-section ul,.doc-section ol{line-height:1.7;padding-inline-start:22px}
.doc-section li{margin:4px 0}
.doc-steps{counter-reset:dstep;list-style:none;padding:0;margin:12px 0}
.doc-steps>li{position:relative;padding:4px 0 14px 44px;line-height:1.6}
.doc-steps>li::before{counter-increment:dstep;content:counter(dstep);position:absolute;inset-inline-start:0;top:2px;width:28px;height:28px;border-radius:50%;background:var(--navy);color:#fff;font-weight:800;font-size:.82rem;display:flex;align-items:center;justify-content:center}
.doc-steps>li:not(:last-child)::after{content:"";position:absolute;inset-inline-start:13px;top:32px;bottom:2px;width:2px;background:var(--border)}
.doc-call{display:flex;gap:11px;padding:12px 15px;border-radius:12px;margin:14px 0;font-size:.9rem;line-height:1.6;border:1px solid var(--border)}
.doc-call .icon{flex:0 0 auto;margin-top:2px}
.doc-tip{background:color-mix(in srgb,var(--green) 9%,var(--surface));border-color:color-mix(in srgb,var(--green) 30%,var(--border));color:var(--text)}
.doc-tip .icon{color:var(--green)}
.doc-note{background:color-mix(in srgb,var(--blue) 8%,var(--surface));border-color:color-mix(in srgb,var(--blue) 30%,var(--border))}
.doc-note .icon{color:var(--blue)}
.doc-warn{background:color-mix(in srgb,var(--amber-c) 10%,var(--surface));border-color:color-mix(in srgb,var(--amber-c) 32%,var(--border))}
.doc-warn .icon{color:var(--amber-c)}
.doc-key{display:inline-block;background:var(--surface-3);border:1px solid var(--border-2);border-bottom-width:2px;border-radius:6px;padding:1px 7px;font-size:.78rem;font-weight:700;font-family:monospace}
.doc-flow{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:12px 0}
.doc-flow .step{background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:7px 11px;font-weight:700;font-size:.8rem}
.doc-footer{border-top:1px solid var(--border);margin-top:30px;padding-top:16px;color:var(--muted);font-size:.85rem;font-weight:600}
@media (max-width:900px){.doc-layout{grid-template-columns:1fr}.doc-toc{position:static;max-height:none}}
@media print{
  .doc-layout{display:block}.doc-toc{display:none}
  .doc-section{page-break-inside:avoid;break-inside:avoid}
  .doc-section,.doc-section *{display:revert}
}
