:root{
  --bg:#eef2f7; --card:#ffffff; --ink:#1f2d3d; --muted:#6b7c93;
  --brand:#15507a; --brand2:#1d6fa5; --line:#d8e2ec; --ok:#1f9d57; --warn:#d98326; --bad:#cc3b3b;
  --shadow:0 1px 3px rgba(20,40,70,.08),0 4px 16px rgba(20,40,70,.06);
}
html[data-theme="dark"]{
  --bg:#0f1722; --card:#16202e; --ink:#e4ecf4; --muted:#93a4b8;
  --brand:#1d6fa5; --brand2:#4aa3d6; --line:#26344a; --ok:#37b06b; --warn:#e0973a; --bad:#e15a5a;
  --shadow:0 1px 3px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.3);
}
html[data-theme="dark"] .sidebar{background:linear-gradient(180deg,#0c1521,#10202f)}
html[data-theme="dark"] .nav a.active{background:#243650;color:#fff}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#0f1925;color:var(--ink)}
html[data-theme="dark"] .kcol{background:#101a26}
html[data-theme="dark"] .kcard,html[data-theme="dark"] .gsearch-results{background:#16202e}
html[data-theme="dark"] .badge-role{background:#243650;color:#cfe2f2}
html[data-theme="dark"] .prog{background:#26344a}
html[data-theme="dark"] td[style*="f7fafc"],html[data-theme="dark"] tr[style*="f7fafc"]{background:#101a26!important}
.theme-toggle{background:none;border:1px solid var(--line);color:var(--muted);border-radius:8px;cursor:pointer;font-size:16px;padding:5px 9px;margin-inline-end:10px}
.theme-toggle:hover{color:var(--ink)}
html[data-theme="dark"] .card .hd{background:#101c2a}
html[data-theme="dark"] th{background:#101c2a;color:#bcd2e6}
html[data-theme="dark"] tbody tr:hover{background:#1b2838}
html[data-theme="dark"] .btn.sec{background:#243650;color:#cfe2f2}
html[data-theme="dark"] .btn.sec:hover{background:#2c425e}
html[data-theme="dark"] .pill.grey{background:#243650;color:#aebfd0}
html[data-theme="dark"] .topbar,html[data-theme="dark"] .gsearch>input{background:var(--card);color:var(--ink)}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Segoe UI","Noto Naskh Arabic","Noto Sans Arabic",Tahoma,sans-serif;
  background:var(--bg);color:var(--ink);direction:rtl;font-size:14px;line-height:1.6}
a{color:var(--brand2);text-decoration:none}
.app{display:flex;min-height:100vh}
.sidebar{width:230px;background:linear-gradient(180deg,#143f63,#15507a);color:#eaf2f9;
  padding:0;position:sticky;top:0;height:100vh;flex-shrink:0;display:flex;flex-direction:column}
.brand{padding:18px 18px 14px;font-size:18px;font-weight:700;border-bottom:1px solid rgba(255,255,255,.12);display:flex;align-items:center;gap:10px}
.brand small{display:block;font-weight:400;font-size:11px;color:#b9d2e6}
.nav{padding:10px;flex:1;overflow:auto}
.nav a{display:flex;align-items:center;gap:10px;color:#dbe9f5;padding:11px 14px;border-radius:9px;margin-bottom:3px;font-weight:600}
.nav a .ic{width:20px;text-align:center}
.nav a:hover{background:rgba(255,255,255,.10)}
.nav a.active{background:#fff;color:var(--brand)}
.nav .sep{height:1px;background:rgba(255,255,255,.12);margin:8px 6px}
.sidebar .foot{padding:12px 16px;border-top:1px solid rgba(255,255,255,.12);font-size:12px;color:#b9d2e6}
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:var(--card);border-bottom:1px solid var(--line);padding:12px 22px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:5}
.topbar h1{font-size:17px;margin:0}
.topbar .who{margin-inline-start:auto;color:var(--muted);font-size:13px}
.topbar .who b{color:var(--ink)}
.badge-role{background:#e8f1f9;color:var(--brand);border-radius:20px;padding:3px 12px;font-size:12px;font-weight:700;margin-inline-start:8px}
.content{padding:22px;flex:1}
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--brand);color:#fff;border:none;border-radius:9px;
  padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.btn:hover{background:var(--brand2)}
.btn.sec{background:#eef3f8;color:var(--brand)}
.btn.sec:hover{background:#e0eaf3}
.btn.ghost{background:transparent;color:var(--brand);border:1px solid var(--line)}
.btn.danger{background:var(--bad)}
.btn.sm{padding:5px 10px;font-size:12px;border-radius:7px}
.btn.ok{background:var(--ok)}
.toolbar{display:flex;gap:9px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.toolbar .spacer{margin-inline-start:auto}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);margin-bottom:18px;overflow:hidden}
.card .hd{padding:13px 18px;border-bottom:1px solid var(--line);font-weight:700;display:flex;align-items:center;gap:8px;background:#f8fafc}
.card .bd{padding:18px}
.grid{display:grid;gap:14px}
.tiles{grid-template-columns:repeat(auto-fill,minmax(165px,1fr))}
.tile{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow)}
.tile .t{font-size:13px;color:var(--muted)}
.tile .v{font-size:24px;font-weight:800;color:var(--brand);margin-top:6px}
.tile.green .v{color:var(--ok)} .tile.warn .v{color:var(--warn)} .tile.bad .v{color:var(--bad)}
table{width:100%;border-collapse:collapse;background:var(--card)}
th,td{padding:10px 12px;text-align:right;border-bottom:1px solid var(--line);font-size:13px;white-space:nowrap}
th{background:#f1f6fb;color:#2a4a66;font-weight:700;position:sticky;top:0}
tbody tr:hover{background:#f7fbff}
.tbl-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:var(--card);max-height:65vh}
.money{font-variant-numeric:tabular-nums;font-weight:600}
.pos{color:var(--ok)} .neg{color:var(--bad)}
.prog{height:8px;background:#e2e8f0;border-radius:6px;overflow:hidden;margin-bottom:2px}
.prog>span{display:block;height:100%;border-radius:6px}
.pill{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:700}
.pill.green{background:#e6f6ec;color:var(--ok)} .pill.warn{background:#fcf0e0;color:var(--warn)}
.pill.bad{background:#fae6e6;color:var(--bad)} .pill.grey{background:#eef2f7;color:var(--muted)}
form .row{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.card .bd>.row{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:16px}
.btn.sm.danger{background:var(--bad)} code{font-family:monospace;font-size:12px}
.bell{position:relative;text-decoration:none;font-size:20px;margin-inline-end:14px}
.bell-badge{position:absolute;top:-6px;inset-inline-end:-8px;background:var(--bad);color:#fff;border-radius:10px;font-size:11px;padding:0 5px;font-weight:700}
.kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(240px,1fr);gap:12px;overflow-x:auto;padding-bottom:8px}
.kcol{background:#f4f7fa;border:1px solid var(--line);border-radius:12px;min-height:120px}
.kcol .khd{padding:9px 12px;font-weight:700;color:#fff;border-radius:12px 12px 0 0;display:flex;justify-content:space-between}
.kcard{background:#fff;border:1px solid var(--line);border-radius:9px;margin:8px;padding:9px;font-size:13px}
.kcard.over{border-inline-start:4px solid var(--bad)}
label.fld{display:block;font-size:13px}
label.fld span{display:block;color:var(--muted);margin-bottom:5px;font-weight:600}
input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:14px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand2);box-shadow:0 0 0 3px rgba(29,111,165,.12)}
textarea{min-height:70px;resize:vertical}
.form-actions{display:flex;gap:10px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.filters{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;align-items:end}
.empty{padding:40px;text-align:center;color:var(--muted)}
.section-title{font-size:15px;font-weight:700;margin:0 0 12px;color:var(--brand)}
/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#143f63,#1d6fa5)}
.login-card{background:#fff;border-radius:18px;box-shadow:0 18px 60px rgba(10,30,60,.35);width:380px;max-width:92vw;padding:34px}
.login-card h2{margin:0 0 4px;color:var(--brand);text-align:center}
.login-card p.sub{margin:0 0 22px;text-align:center;color:var(--muted);font-size:13px}
.login-card .err{background:#fae6e6;color:var(--bad);padding:10px 12px;border-radius:9px;font-size:13px;margin-bottom:14px;text-align:center}
.login-logo{width:62px;height:62px;border-radius:16px;background:linear-gradient(135deg,#15507a,#1d6fa5);
  margin:0 auto 14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:800}
/* Global search box (top bar) */
.gsearch{position:relative;flex:1;max-width:420px;margin-inline-start:auto}
.gsearch>input{padding:8px 12px;border-radius:20px;font-size:13px}
.gsearch-results{display:none;position:absolute;top:42px;inset-inline-start:0;inset-inline-end:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 36px rgba(10,30,60,.18);z-index:40;max-height:380px;overflow:auto}
.gsearch-results a{display:grid;grid-template-columns:auto 1fr;gap:4px 8px;padding:9px 12px;text-decoration:none;color:var(--ink);border-bottom:1px solid var(--line)}
.gsearch-results a:hover{background:#f4f7fa}
.gsearch-results .gs-type{grid-row:span 2;align-self:center;background:#eef3f7;color:var(--brand);border-radius:8px;padding:3px 8px;font-size:11px;font-weight:700}
.gsearch-results .gs-title{font-weight:700;font-size:13px}
.gsearch-results .gs-sub{color:var(--muted);font-size:11px}
.gsearch-results .gs-empty{padding:14px;text-align:center;color:var(--muted);font-size:13px}
@media(max-width:760px){.sidebar{position:fixed;right:-240px;transition:.2s;z-index:30}.sidebar.open{right:0}.menu-btn{display:inline-flex!important}.gsearch{display:none}}
.menu-btn{display:none}
/* User dropdown */
.user-dd{display:none;position:absolute;top:calc(100% + 6px);left:0;background:var(--card);border:1px solid var(--line);border-radius:8px;min-width:160px;z-index:9999;box-shadow:var(--shadow);padding:4px 0}
.user-dd.open{display:block}
.user-dd a{display:block;padding:8px 16px;text-decoration:none;color:var(--ink);font-size:13px}
.user-dd a:hover{background:var(--bg)}
/* Pill colors */
.pill.ok{background:#d4f4e0;color:#1a6e3f}
.pill.bad{background:#fde0e0;color:#8a1515}
.pill.warn{background:#fdefd5;color:#915a00}
/* Money classes */
.money.bad{color:var(--bad)}
/* Receipt print */
@media print{.sidebar,.topbar,.toolbar,.btn,.form-actions{display:none!important}.content{margin:0!important;padding:0!important}.card{box-shadow:none!important;border:1px solid #ccc!important}}
/* Full-screen table toggle */
.table-fullscreen{position:fixed!important;inset:0;z-index:7000;background:var(--bg);overflow:auto;padding:20px}
/* Improved input focus */
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand2);box-shadow:0 0 0 3px rgba(29,111,165,.15)}
