/* ============================================================
   Sijill — Document Archive & OCR (government archival design)
   Ported from the approved mockup. Bilingual EN/AR with RTL overrides.
   Fonts: IBM Plex (self-host for air-gapped prod; system fallbacks below).
   ============================================================ */
:root{
  --ink:#15233B; --ink-2:#22344F; --ink-3:#2E445F;
  --gold:#C19A3E; --gold-soft:#EFE3C2;
  --app-bg:#EBEEF3; --surface:#FFFFFF; --surface-2:#F7F8FA; --paper:#FCFBF7;
  --text:#1B2436; --muted:#6A7689; --muted-2:#9AA4B4;
  --line:#E2E6EC; --line-2:#EDEFF3;
  --ok:#2F7D5B; --ok-bg:#E5F2EB;
  --warn:#B5832E; --warn-bg:#FBF1DC;
  --bad:#B23A3A; --bad-bg:#F8E6E5;
  --info:#2C5E8F; --info-bg:#E5EEF6;
  --radius:10px; --radius-sm:7px;
  --shadow:0 1px 2px rgba(21,35,59,.06), 0 6px 18px rgba(21,35,59,.06);
  --shadow-lg:0 12px 40px rgba(21,35,59,.16);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:"IBM Plex Sans",system-ui,"Segoe UI","Cairo",sans-serif;background:var(--app-bg);color:var(--text);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
html[dir="rtl"] body{font-family:"Cairo","IBM Plex Sans","Segoe UI",system-ui,sans-serif}
.mono{font-family:"IBM Plex Mono","Cascadia Mono",monospace}
.serif{font-family:"IBM Plex Serif",Georgia,serif}
h1,h2,h3,h4{margin:0;font-weight:600}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--gold-soft)}

/* layout shell */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* sidebar */
.side{background:linear-gradient(180deg,var(--ink) 0%,#111d31 100%);color:#C7D0DE;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:40}
.brand{display:flex;align-items:center;gap:11px;padding:20px 20px 18px}
.seal{width:38px;height:38px;border-radius:9px;flex:none;background:var(--paper);display:grid;place-items:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18),0 2px 6px rgba(0,0,0,.28);overflow:hidden}
.seal img{width:82%;height:82%;display:block;pointer-events:none}
.brand .name{font-family:"IBM Plex Serif",Georgia,serif;font-weight:600;font-size:18px;color:#fff;letter-spacing:.2px}
.brand .sub{font-size:10.5px;color:#7F8DA3;letter-spacing:1.5px;text-transform:uppercase;margin-top:1px}
.nav{padding:6px 12px;overflow-y:auto;flex:1}
.nav-label{font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:#5E6B82;padding:14px 10px 6px}
.nav-item{display:flex;align-items:center;gap:11px;width:100%;text-align:start;background:none;border:0;color:#BAC4D4;padding:9px 11px;border-radius:8px;font-size:13.5px;margin:1px 0;position:relative;transition:background .15s,color .15s}
.nav-item:hover{background:rgba(255,255,255,.05);color:#fff}
.nav-item.active{background:rgba(193,154,62,.16);color:#fff}
.nav-item.active::before{content:"";position:absolute;inset-inline-start:-12px;top:7px;bottom:7px;width:3px;background:var(--gold);border-radius:0 3px 3px 0}
.nav-item svg{width:18px;height:18px;flex:none;opacity:.92}
.nav-item .badge{margin-inline-start:auto;background:var(--bad);color:#fff;font-size:10.5px;font-weight:600;border-radius:20px;padding:1px 7px;font-family:"IBM Plex Mono",monospace}
.nav-item.active .badge{background:var(--gold);color:#2a2104}
.side-foot{padding:12px 16px;border-top:1px solid rgba(255,255,255,.07);font-size:11px;color:#6B7891;display:flex;align-items:center;gap:8px}
.dot-live{width:7px;height:7px;border-radius:50%;background:#43c47a;box-shadow:0 0 0 3px rgba(67,196,122,.2)}

/* topbar */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:62px;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 22px;position:sticky;top:0;z-index:30}
.crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.crumb b{color:var(--text);font-weight:600}
.crumb .sep{color:var(--muted-2)}
.topsearch{margin-inline-start:auto;position:relative;width:300px;max-width:38vw}
.topsearch input{width:100%;height:38px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);padding:0 12px 0 36px;font-family:inherit;font-size:13px;color:var(--text)}
html[dir="rtl"] .topsearch input{padding:0 36px 0 12px}
.topsearch input:focus{outline:2px solid var(--gold);outline-offset:0;border-color:transparent;background:#fff}
.topsearch svg{position:absolute;inset-inline-start:11px;top:10px;width:18px;height:18px;color:var(--muted-2)}
.role-switch{display:flex;align-items:center;gap:8px}
.role-switch label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.role-pill{height:38px;display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);padding:0 11px;font-size:12.5px;color:var(--text);font-weight:600}
.icon-btn{width:38px;height:38px;border:1px solid var(--line);background:var(--surface-2);border-radius:8px;display:grid;place-items:center;color:var(--muted);position:relative}
.icon-btn:hover{color:var(--text);background:#fff}
.icon-btn .ping{position:absolute;top:8px;inset-inline-end:9px;width:7px;height:7px;border-radius:50%;background:var(--bad);border:2px solid #fff}
.avatar{width:38px;height:38px;border-radius:9px;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px;font-family:"IBM Plex Serif",Georgia,serif}
.menu-toggle{display:none}

/* content */
.content{padding:24px;max-width:1320px;width:100%;margin:0 auto}
.screen{animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.page-title{font-family:"IBM Plex Serif",Georgia,serif;font-size:25px;font-weight:600;letter-spacing:-.2px}
.page-sub{color:var(--muted);font-size:13px;margin-top:3px}
.head-actions{display:flex;gap:10px;flex-wrap:wrap}

.btn{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 15px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--text);font-size:13px;font-weight:500;transition:.15s;text-decoration:none}
.btn:hover{border-color:var(--muted-2)}
.btn svg{width:16px;height:16px}
.btn.primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.primary:hover{background:var(--ink-2)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#2c2206}
.btn.gold:hover{background:#d0a948}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn.ghost:hover{background:var(--line-2);color:var(--text)}
.btn.ok{background:var(--ok);border-color:var(--ok);color:#fff}
.btn.bad{background:#fff;border-color:#e3c4c4;color:var(--bad)}
.btn.bad:hover{background:var(--bad-bg)}
.btn.sm{height:32px;padding:0 11px;font-size:12.5px}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:18px}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--line-2)}
.card-head h3{font-size:14.5px;font-weight:600}
.card-head .hint{font-size:12px;color:var(--muted)}
.grid{display:grid;gap:18px}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}

.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 17px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .label{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;display:flex;align-items:center;gap:7px}
.kpi .num{font-family:"IBM Plex Serif",Georgia,serif;font-size:33px;font-weight:600;letter-spacing:-.5px;margin-top:9px;line-height:1}
.kpi .delta{font-size:12px;margin-top:9px;font-weight:500;font-family:"IBM Plex Mono",monospace}
.delta.up{color:var(--ok)}.delta.down{color:var(--bad)}.delta.flat{color:var(--muted)}
.kpi .ico{position:absolute;top:14px;inset-inline-end:14px;width:30px;height:30px;border-radius:8px;display:grid;place-items:center}
.kpi .ico svg{width:17px;height:17px}

.chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px}
.chip .d{width:6px;height:6px;border-radius:50%}
.chip.ok{background:var(--ok-bg);color:var(--ok)}.chip.ok .d{background:var(--ok)}
.chip.warn{background:var(--warn-bg);color:var(--warn)}.chip.warn .d{background:var(--warn)}
.chip.bad{background:var(--bad-bg);color:var(--bad)}.chip.bad .d{background:var(--bad)}
.chip.info{background:var(--info-bg);color:var(--info)}.chip.info .d{background:var(--info)}
.chip.mute{background:var(--surface-2);color:var(--muted);border:1px solid var(--line)}.chip.mute .d{background:var(--muted-2)}

table{width:100%;border-collapse:collapse}
thead th{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);text-align:start;padding:11px 16px;border-bottom:1px solid var(--line);background:var(--surface-2);font-weight:600}
tbody td{padding:12px 16px;border-bottom:1px solid var(--line-2);font-size:13px;vertical-align:middle}
tbody tr:hover{background:var(--surface-2)}
tbody tr:last-child td{border-bottom:0}
.t-id{font-family:"IBM Plex Mono",monospace;font-size:12px;color:var(--info);font-weight:500}
.t-strong{font-weight:600}.t-mute{color:var(--muted)}

.barchart{display:flex;align-items:flex-end;gap:10px;height:160px;padding:6px 2px 0}
.barchart .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}
.barchart .stack{width:60%;max-width:34px;border-radius:5px 5px 2px 2px;background:linear-gradient(180deg,var(--ink-3),var(--ink));transition:.3s}
.barchart .col:hover .stack{filter:brightness(1.15)}
.barchart .cap{font-size:10.5px;color:var(--muted);font-family:"IBM Plex Mono",monospace}

.donut-wrap{display:flex;align-items:center;gap:22px}
.legend{display:flex;flex-direction:column;gap:11px;font-size:13px}
.legend .row{display:flex;align-items:center;gap:9px}
.legend .sw{width:11px;height:11px;border-radius:3px}
.legend .v{margin-inline-start:auto;font-family:"IBM Plex Mono",monospace;font-weight:600}

.review-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:18px;align-items:start}
.doc-pane{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.doc-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--line-2);background:var(--surface-2)}
.doc-toolbar .spacer{flex:1}
.doc-stage{background:#dfe3ea;padding:22px;display:grid;place-items:center;min-height:300px}
.slip{position:relative;width:430px;max-width:100%;background:var(--paper);box-shadow:0 4px 18px rgba(21,35,59,.22);border:1px solid #ece6d6;padding:30px 30px 34px;font-family:"IBM Plex Mono",monospace;color:#2a2a26}
.slip .gov{text-align:center;border-bottom:2px solid #2a2a26;padding-bottom:11px;margin-bottom:16px}
.slip .gov .t1{font-size:11px;letter-spacing:1px}
.slip .gov .t2{font-family:"IBM Plex Serif",Georgia,serif;font-weight:700;font-size:15px;letter-spacing:1px;margin-top:3px}
.slip .rowf{display:flex;justify-content:space-between;gap:14px;font-size:12px;margin:11px 0;align-items:baseline}
.slip .rowf .k{color:#6a675c}
.slip .rowf .v{font-weight:600;text-align:end}
.slip .stamp{position:absolute;inset-inline-end:24px;bottom:20px;width:74px;height:74px;border:2px solid #9a3636;border-radius:50%;color:#9a3636;display:grid;place-items:center;text-align:center;font-size:8px;font-weight:700;transform:rotate(-14deg);opacity:.78;line-height:1.25;letter-spacing:.5px}

.field-list{display:flex;flex-direction:column}
.frow{display:grid;grid-template-columns:1fr auto;gap:4px 12px;padding:13px 16px;border-bottom:1px solid var(--line-2);cursor:pointer;transition:.12s}
.frow:hover,.frow.hot{background:var(--surface-2)}
.frow .fk{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);grid-column:1}
.frow .fc{grid-column:2;grid-row:1/3;align-self:center}
.frow .fv{font-size:14px;font-weight:600;font-family:"IBM Plex Mono",monospace}
.conf{font-family:"IBM Plex Mono",monospace;font-size:11px;font-weight:600;padding:2px 7px;border-radius:6px}
.conf.ok{background:var(--ok-bg);color:var(--ok)}
.conf.warn{background:var(--warn-bg);color:var(--warn)}
.conf.bad{background:var(--bad-bg);color:var(--bad)}

.match{display:flex;align-items:center;gap:11px;padding:11px 14px;border:1px solid var(--line);border-radius:8px;margin-bottom:8px;transition:.15s}
.match:hover{border-color:var(--gold);background:#fffdf6}
.match .mscore{font-family:"IBM Plex Mono",monospace;font-weight:600;font-size:13px}
.match .pick{margin-inline-start:auto}

.progress{height:7px;border-radius:6px;background:var(--line);overflow:hidden}
.progress>i{display:block;height:100%;border-radius:6px}

.tree{font-size:13px;user-select:none}
.tnode{padding:6px 9px;border-radius:7px;display:flex;align-items:center;gap:8px;cursor:pointer}
.tnode:hover{background:var(--surface-2)}
.tnode.sel{background:var(--gold-soft);color:#5a4410;font-weight:600}
.tnode svg{width:15px;height:15px;color:var(--gold);flex:none}
.tnode .ct{margin-inline-start:auto;font-family:"IBM Plex Mono",monospace;font-size:11px;color:var(--muted)}
.tchild{margin-inline-start:14px;border-inline-start:1px solid var(--line);padding-inline-start:6px}

.sec-banner{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:12.5px;margin-bottom:16px;border:1px solid}
.sec-banner.info{background:var(--info-bg);border-color:#cfe0ef;color:var(--info)}
.sec-banner.warn{background:var(--warn-bg);border-color:#e9d6ad;color:var(--warn)}
.sec-banner.bad{background:var(--bad-bg);border-color:#e8c9c9;color:var(--bad)}

.kv{display:grid;grid-template-columns:160px 1fr;gap:11px 18px;font-size:13.5px}
.kv .k{color:var(--muted)}
.kv .v{font-weight:500}

.perm-cell{text-align:center;vertical-align:middle}
.perm-cell svg{width:17px;height:17px;vertical-align:middle}
.perm-cell .yes,.perm-cell .no{display:inline-flex;align-items:center;justify-content:center}
.yes{color:var(--ok)}.no{color:var(--muted-2)}

.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:3px;gap:2px}
.seg button,.seg a{border:0;background:none;padding:6px 13px;border-radius:6px;font-size:12.5px;color:var(--muted);font-weight:500;text-decoration:none}
.seg button.on,.seg a.on{background:#fff;color:var(--text);box-shadow:var(--shadow)}

.timeline{position:relative;padding-inline-start:22px}
.timeline::before{content:"";position:absolute;inset-inline-start:6px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;padding:0 0 18px 0}
.tl-item::before{content:"";position:absolute;inset-inline-start:-19px;top:3px;width:11px;height:11px;border-radius:50%;background:#fff;border:2.5px solid var(--gold)}
.tl-item.del::before{border-color:var(--bad)}
.tl-item.add::before{border-color:var(--ok)}
.tl-time{font-size:11px;color:var(--muted-2);font-family:"IBM Plex Mono",monospace}
.tl-act{font-size:13.5px;margin-top:2px}
.tl-meta{font-size:12px;color:var(--muted);margin-top:3px}
.diff-old{background:var(--bad-bg);color:var(--bad);padding:1px 6px;border-radius:4px;text-decoration:line-through;font-family:"IBM Plex Mono",monospace;font-size:12px}
.diff-new{background:var(--ok-bg);color:var(--ok);padding:1px 6px;border-radius:4px;font-family:"IBM Plex Mono",monospace;font-size:12px}

.facet{border-bottom:1px solid var(--line-2);padding:14px 0}
.facet:first-child{padding-top:0}
.facet h4{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:10px}
.check{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:13px;cursor:pointer}
.check input{accent-color:var(--ink);width:15px;height:15px}
.check .cnt{margin-inline-start:auto;font-family:"IBM Plex Mono",monospace;font-size:11px;color:var(--muted-2)}

.uploadbox{border:2px dashed var(--line);border-radius:12px;padding:34px;text-align:center;background:var(--surface-2);transition:.2s}
.uploadbox:hover{border-color:var(--gold);background:#fffdf6}
.uploadbox .big{width:46px;height:46px;border-radius:12px;background:var(--gold-soft);display:grid;place-items:center;margin:0 auto 12px;color:#7a5d12}

.stepflow{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:9px;padding:8px 14px;border:1px solid var(--line);background:#fff;font-size:12.5px;font-weight:500;position:relative}
.step:first-child{border-radius:8px 0 0 8px}
.step:last-child{border-radius:0 8px 8px 0}
html[dir="rtl"] .step:first-child{border-radius:0 8px 8px 0}
html[dir="rtl"] .step:last-child{border-radius:8px 0 0 8px}
.step .n{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-family:"IBM Plex Mono",monospace;font-weight:600;background:var(--surface-2);color:var(--muted)}
.step.done{background:var(--ok-bg);border-color:#cce3d6;color:var(--ok)}.step.done .n{background:var(--ok);color:#fff}
.step.cur{background:var(--ink);border-color:var(--ink);color:#fff}.step.cur .n{background:var(--gold);color:#2c2206}

.agent-card{display:flex;align-items:center;gap:14px;padding:15px;border:1px solid var(--line);border-radius:10px;background:#fff}
.agent-ico{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;flex:none}

.muted{color:var(--muted)}.small{font-size:12px}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.flex{display:flex;align-items:center;gap:10px}.wrap{flex-wrap:wrap}

.field-input{width:100%;height:38px;border:1px solid var(--line);border-radius:8px;background:var(--surface-2);padding:0 12px;font-family:inherit;font-size:13px;color:var(--text)}
.field-input:focus{outline:2px solid var(--gold);background:#fff;border-color:transparent}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 18px;border-radius:10px;font-size:13px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:.3s;z-index:90}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast svg{width:18px;height:18px;color:var(--gold)}

@media (max-width:1080px){.g-4{grid-template-columns:repeat(2,1fr)}.review-grid{grid-template-columns:1fr}.donut-wrap{flex-direction:column;align-items:flex-start}}
@media (max-width:860px){
  .app{grid-template-columns:1fr}
  .side{position:fixed;inset-inline-start:0;top:0;width:260px;transform:translateX(-100%);transition:transform .25s;box-shadow:var(--shadow-lg)}
  html[dir="rtl"] .side{transform:translateX(100%)}
  body.nav-open .side{transform:none}
  .menu-toggle{display:grid}
  .scrim{position:fixed;inset:0;background:rgba(15,25,45,.45);opacity:0;pointer-events:none;transition:.25s;z-index:35}
  body.nav-open .scrim{opacity:1;pointer-events:auto}
  .g-3,.g-2{grid-template-columns:1fr}
  .topsearch{display:none}
  .kv{grid-template-columns:1fr}
}
@media (max-width:560px){.g-4{grid-template-columns:1fr}.content{padding:16px}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:4px}
