:root{
  --blue:#000091; --blue-d:#000077; --blue-soft:#ECECFB; --blue-soft2:#F5F5FE;
  --ink:#161616; --ink2:#3a3a3a; --ink3:#5a5a66; --muted:#7a7a86; --muted2:#9696a0;
  --bg:#EEEEF4; --line:#E3E3EC; --line2:#EEEEF4; --panel:#fff; --panel2:#FAFAFD; --panel3:#F4F4F9;
  --ok-bg:#DCFCE3; --ok:#0F6B33; --ok-dot:#18A957;
  --red:#E1000F; --red-d:#B81414; --red-bg:#FFE3E3;
  --amber-bg:#FEF3CD; --amber:#7A5200; --amber-dot:#C58A00;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:'Libre Franklin',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}
body.ar{font-family:'IBM Plex Sans Arabic','Libre Franklin',sans-serif}
.boot{padding:60px;text-align:center;color:var(--muted)}
.mono{font-family:'IBM Plex Mono',monospace}
input::placeholder{color:var(--muted2)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cfcfd8;border-radius:8px;border:2px solid transparent;background-clip:content-box}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
@keyframes barflow{from{background-position:0 0}to{background-position:40px 0}}

button{font-family:inherit;cursor:pointer;border:0}
input,select{font-family:inherit}
.accent{height:4px;background:var(--blue)}

/* layout */
.shell{min-height:100vh;display:flex;flex-direction:column}
.layout{flex:1;display:flex;min-height:0}
header.top{display:flex;align-items:center;gap:24px;height:62px;padding:0 28px;background:#fff;border-bottom:1px solid var(--line);flex-shrink:0;z-index:5}
.logo{width:40px;height:40px;border-radius:9px;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;letter-spacing:.5px;flex-shrink:0}
.brandName{font-weight:700;font-size:15px}
.brandSub{font-size:12px;color:var(--muted);font-weight:500}
.search{display:flex;align-items:center;gap:10px;height:40px;padding:0 14px;background:var(--panel3);border:1px solid var(--line);border-radius:9px;color:var(--muted2)}
.search input{border:0;outline:0;background:transparent;flex:1;font-size:13.5px;color:var(--ink)}
.iconbtn{display:flex;align-items:center;gap:7px;height:36px;padding:0 13px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:13px;font-weight:600;color:var(--blue)}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}

aside.side{width:262px;flex-shrink:0;background:#fff;border-inline-end:1px solid var(--line);display:flex;flex-direction:column;padding:18px 0}
.side .lab{padding:0 18px 10px;font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted2)}
.side nav{display:flex;flex-direction:column;gap:3px;padding-inline-end:12px}
.navbtn{display:flex;align-items:center;gap:12px;padding:11px 16px;background:transparent;color:var(--ink2);font-weight:500;font-size:14px;border-inline-start:3px solid transparent;width:100%;text-align:start;border-radius:0 8px 8px 0}
.navbtn.active{background:var(--blue-soft);color:var(--blue);font-weight:600;border-inline-start-color:var(--blue)}

main.main{flex:1;min-width:0;overflow:auto;padding:30px 36px 56px}
.wrap{margin:0 auto}
.kicker{font-size:12px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
h1.title{font-size:27px;font-weight:800;letter-spacing:-.4px}
.lead{font-size:14.5px;color:var(--ink3);line-height:1.55;max-width:600px;margin-top:8px}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:22px 0 26px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:13px;padding:17px 18px}
.kpi .l{font-size:12.5px;color:var(--muted);font-weight:500;margin-bottom:9px}
.kpi .v{font-size:30px;font-weight:800;letter-spacing:-1px;font-variant-numeric:tabular-nums}

.filterbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.fsearch{display:flex;align-items:center;gap:10px;height:42px;padding:0 14px;background:#fff;border:1px solid var(--line);border-radius:10px;color:var(--muted2);flex:1;min-width:230px;max-width:340px}
.fsearch input{border:0;outline:0;background:transparent;flex:1;font-size:13.5px;color:var(--ink)}
.chip{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 13px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--ink2);font-size:13px;font-weight:600}
.chip.active{border-color:var(--blue);background:var(--blue);color:#fff}
.chip .c{font-size:11.5px;font-weight:700;padding:1px 7px;border-radius:20px;background:#F0F0F6;color:var(--muted);font-variant-numeric:tabular-nums}
.chip.active .c{background:rgba(255,255,255,.22);color:#fff}
.linkbtn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 12px;background:transparent;color:var(--blue);font-size:13px;font-weight:600}

.centers{display:flex;flex-direction:column;gap:16px}
.center{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.center .head{display:flex;align-items:center;gap:16px;padding:16px 20px;cursor:pointer}
.chev{color:var(--muted);transition:transform .2s;flex-shrink:0}
.code{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:14px;background:var(--blue-soft);color:var(--blue);padding:4px 9px;border-radius:6px}
.cname{font-weight:700;font-size:15.5px}
.ccity{font-size:12.5px;color:var(--muted)}
.cmeta{margin-inline-start:auto;display:flex;align-items:center;gap:18px}
.cmeta .n{font-size:13px;color:var(--ink2);font-weight:500}
.btn-primary{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 14px;background:var(--blue);color:#fff;border-radius:8px;font-size:13px;font-weight:600}
.btn-primary:hover{background:var(--blue-d)}
.btn-primary:disabled{background:#b8b8c6;cursor:not-allowed}
.btn-ghost{height:42px;padding:0 20px;background:#fff;border:1px solid var(--line);border-radius:9px;font-size:14px;font-weight:600;color:var(--ink2)}
.btn-ghost.sm{height:34px;padding:0 13px;font-size:12.5px}

.cbody{padding:6px 20px 18px}
.grouphd{display:flex;align-items:center;gap:10px;margin:14px 0 8px}
.gcode{font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:13px;background:var(--panel3);border:1px solid var(--line);padding:3px 9px;border-radius:6px}
.gcount{font-size:12.5px;color:var(--muted)}
.rule{flex:1;height:1px;background:var(--line2)}
.tbl{border:1px solid var(--line2);border-radius:10px;overflow:hidden}
.tbl.dashed{border:1px dashed #D9D9E4}
.trow{display:grid;grid-template-columns:2fr 1fr 1fr;align-items:center;padding:11px 16px;border-top:1px solid var(--panel3);font-size:13.5px}
.select{height:42px;padding:0 34px 0 12px;border:1px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 24 24" fill="none" stroke="%237a7a86" stroke-width="2.4"><path d="M6 9l6 6 6-6"/></svg>');background-repeat:no-repeat;background-position:right 12px center;max-width:280px}
.select.sm{height:34px;font-size:13px}
body.ar .select{background-position:left 12px center;padding:0 12px 0 34px}
.trow.hd{padding:9px 16px;background:var(--panel2);font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted2);border-top:0}
.rlabel{font-weight:600}
.tcell{color:var(--ink2)}
.num{font-variant-numeric:tabular-nums}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px}
.badge .dot{width:6px;height:6px;border-radius:50%}

.empty{background:#fff;border:1px solid var(--line);border-radius:14px;padding:48px 24px;text-align:center}
.empty .ic{width:56px;height:56px;margin:0 auto 16px;border-radius:14px;background:var(--panel3);display:flex;align-items:center;justify-content:center}
.empty h3{font-size:16px;font-weight:700;margin-bottom:7px}
.empty p{font-size:13.5px;color:var(--muted);line-height:1.5;max-width:380px;margin:0 auto 18px}

/* import */
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px}
.dropzone{border:2px dashed #C7C7E0;border-radius:12px;padding:34px 22px;text-align:center;background:var(--panel2);transition:border-color .15s,background .15s}
.dropzone.drag{border-color:var(--blue);background:var(--blue-soft2)}
.dropzone .ic{width:54px;height:54px;margin:0 auto 14px;border-radius:13px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--blue)}
.dz-title{font-size:15px;font-weight:700;margin-bottom:5px}
.dz-sub{font-size:13px;color:var(--muted);margin-bottom:16px}
.istats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:20px 0}
.istat{background:var(--panel2);border:1px solid var(--line2);border-radius:11px;padding:14px 16px}
.istat .v{font-size:24px;font-weight:800;color:var(--blue);font-variant-numeric:tabular-nums}
.istat .l{font-size:12.5px;color:var(--muted);font-weight:500;margin-top:3px}
.filecard{display:flex;align-items:center;gap:16px;padding:16px 18px;background:#F7FBF8;border:1px solid #CDEBD6;border-radius:11px;margin-bottom:20px}
.filecard .ic{width:42px;height:42px;border-radius:9px;background:#fff;border:1px solid #CDEBD6;display:flex;align-items:center;justify-content:center;color:var(--ok);flex-shrink:0}
.subt{font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted2);margin-bottom:9px}
.ipreview{display:grid;grid-template-columns:1fr 1.4fr 1fr;align-items:center;padding:11px 16px;border-top:1px solid var(--panel3);font-size:13.5px}
.ipreview.hd{padding:10px 16px;background:var(--panel2);font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted2);border-top:0}
.warn{background:#FFF7ED;border:1px solid #FED7AA;color:#9A3412;padding:11px 14px;border-radius:9px;font-size:12.5px;margin-bottom:16px}
.actions{display:flex;justify-content:flex-end;gap:11px;margin-top:22px}

/* progress bar */
.progress{margin:18px 0 4px}
.progress .meta{display:flex;justify-content:space-between;font-size:12.5px;color:var(--muted);margin-bottom:7px}
.progress .meta b{color:var(--ink)}
.track{height:9px;border-radius:20px;background:#E7E7F0;overflow:hidden}
.fill{height:100%;border-radius:20px;background:var(--blue);transition:width .25s ease}
.fill.indet{width:40% !important;background:linear-gradient(90deg,var(--blue) 0 50%,#5b5bd6 50% 100%);background-size:40px 9px;animation:barflow .8s linear infinite;animation-direction:normal}
.fill.ok{background:var(--ok-dot)}

/* directors */
.dirgrid{display:grid;grid-template-columns:1.4fr 1.6fr 1.2fr 1fr;align-items:center;padding:14px 22px;border-top:1px solid var(--panel3);font-size:13.5px}
.dirgrid.hd{padding:13px 22px;background:var(--panel2);font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted2);border-top:0}
.diravatar{width:32px;height:32px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}

/* no center */
.nocenter{max-width:560px;margin:9vh auto 0;text-align:center}
.nocenter .ic{width:74px;height:74px;margin:0 auto 22px;border-radius:18px;background:#FFE9E9;display:flex;align-items:center;justify-content:center}
.nocenter h1{font-size:23px;font-weight:800;letter-spacing:-.3px;margin-bottom:13px;line-height:1.3}
.nocenter p{font-size:15px;color:var(--ink3);line-height:1.65;margin-bottom:26px}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(22,22,30,.42);display:flex;align-items:center;justify-content:center;padding:24px;z-index:50;animation:fadeIn .2s ease}
.modal{width:600px;max-width:100%;max-height:88vh;background:#fff;border-radius:16px;display:flex;flex-direction:column;overflow:hidden;animation:pop .28s ease both}
.modal .mhd{padding:22px 24px 18px;border-bottom:1px solid var(--line2)}
.modal h2{font-size:19px;font-weight:800;letter-spacing:-.2px}
.modal .mbody{padding:10px 12px;overflow:auto;flex:1}
.mroom{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:10px;cursor:pointer;border:1px solid var(--line2);background:#fff;margin:4px 0;transition:background .12s}
.mroom.sel{background:var(--blue-soft2);border-color:#C7C7F2}
.mroom.dis{opacity:.45;cursor:not-allowed}
.cbox{width:21px;height:21px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid #cfcfd8}
.mroom.sel .cbox{background:var(--blue);border-color:var(--blue)}
.mfoot{padding:16px 24px;border-top:1px solid var(--line2);display:flex;align-items:center;gap:16px}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}
.login{width:100%;max-width:392px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px;box-shadow:0 10px 40px rgba(20,30,60,.08)}
.login .logo{margin-bottom:18px}
.login h1{font-size:21px;font-weight:800;letter-spacing:-.3px;margin-bottom:4px}
.login p{color:var(--muted);font-size:14px;margin-bottom:22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink2);margin-bottom:6px}
.field input{width:100%;height:44px;padding:0 13px;border:1px solid var(--line);border-radius:9px;font-size:14px;background:#fff}
.field input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}
.btn-block{width:100%;height:46px;background:var(--blue);color:#fff;border-radius:10px;font-size:14.5px;font-weight:600}
.btn-block:hover{background:var(--blue-d)}
.err{background:#FDECEC;color:var(--red-d);border:1px solid #F5C6C6;padding:10px 12px;border-radius:9px;font-size:13.5px;margin-bottom:14px}
.ok-msg{background:#E7F6EC;color:var(--ok);border:1px solid #B7E3C5;padding:10px 12px;border-radius:9px;font-size:13.5px}

[hidden]{display:none !important}
