
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --g:#13795B;--gm:#1D9E75;--gl:#E8F7F2;--gb:#9FE1CB;
  --am:#C07A1A;--al:#FDF3E3;--ab:#F0C060;
  --rm:#B03030;--rl:#FDF0F0;--rb:#F0AAAA;
  --bm:#1A5FA8;--bl:#EBF3FD;--bb:#90BFED;
  --pm:#6B21A8;--pl:#F5F0FF;--pb:#C4B5FD;
  --ink:#1C1C1E;--ink2:#444;--ink3:#777;--ink4:#AAA;
  --s:#fff;--bg:#F5F6F8;--bdr:#E4E4E4;--bdr2:#F0F0F0;
  --r:10px;--rl2:16px;
}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--ink);height:100vh;overflow:hidden;display:flex}

/* ── Sidebar ── */
.sidebar{width:56px;background:var(--ink);display:flex;flex-direction:column;align-items:center;padding:14px 0;gap:2px;flex-shrink:0}
.s-logo{width:32px;height:32px;border-radius:8px;background:var(--gm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:600;margin-bottom:12px}
.s-item{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.35);cursor:pointer;font-size:17px;text-decoration:none}
.s-item.on{background:rgba(255,255,255,0.12);color:#fff}

/* ── Shell ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:48px;background:var(--s);border-bottom:1px solid var(--bdr);display:flex;align-items:center;padding:0 20px;gap:6px;flex-shrink:0}
.topbar-title{font-size:14px;font-weight:600}
.layout{flex:1;display:flex;overflow:hidden}
.left-scroll{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px}
.right-panel{width:298px;border-left:1px solid var(--bdr);background:var(--s);overflow-y:auto;flex-shrink:0}

/* ── Cards ── */
.card{background:var(--s);border:1px solid var(--bdr);border-radius:var(--rl2);padding:18px}
.card-head{display:flex;align-items:center;gap:8px;margin-bottom:14px;position:relative}
.card-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ci-g{background:var(--gl)}.ci-b{background:var(--bl)}.ci-a{background:var(--al)}.ci-p{background:var(--pl)}
.card-label{font-size:12px;font-weight:600;color:var(--ink2);flex:1}

/* ── KPI row ── */
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.kpi-box{background:var(--s);border:1px solid var(--bdr);border-radius:var(--rl2);padding:14px 16px}
.kpi-n{font-size:30px;font-weight:700;line-height:1;letter-spacing:-0.5px}
.kpi-l{font-size:11px;color:var(--ink4);margin-top:4px;line-height:1.35}
.kpi-sub{font-size:10px;font-weight:600;margin-top:8px;padding:2px 7px;border-radius:20px;display:inline-block}
.k-pub .kpi-n{color:var(--bm)}.k-pub .kpi-sub{background:var(--bl);color:var(--bm)}
.k-tak .kpi-n{color:var(--g)}.k-tak .kpi-sub{background:var(--gl);color:var(--g)}
.k-risk .kpi-n{color:#C04A00}.k-risk .kpi-sub{background:#FFF0E8;color:#C04A00}
.k-can .kpi-n{color:var(--rm)}.k-can .kpi-sub{background:var(--rl);color:var(--rm)}
.k-com .kpi-n{color:var(--ink)}.k-com .kpi-sub{background:var(--bg);color:var(--ink4);border:1px solid var(--bdr)}

/* ── Popovers ── */
.br-btn{width:16px;height:16px;border-radius:50%;background:var(--bl);border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--bm);font-size:10px;font-weight:700;flex-shrink:0;transition:background .15s;font-family:'DM Sans',sans-serif;line-height:1}
.br-btn:hover,.br-btn.active{background:var(--bm);color:#fff}
.q-btn{width:16px;height:16px;border-radius:50%;background:var(--rl);border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--rm);font-size:10px;font-weight:700;flex-shrink:0;transition:background .15s;font-family:'DM Sans',sans-serif;line-height:1}
.q-btn:hover,.q-btn.active{background:var(--rm);color:#fff}
.pop{display:none;position:absolute;z-index:400;width:290px;border-radius:12px;padding:14px;box-shadow:0 8px 30px rgba(0,0,0,.25);font-size:12px;line-height:1.6;top:calc(100% + 6px);left:0}
.pop.right{left:auto;right:0}.pop.on{display:block}
.pop-info{background:var(--ink);color:#fff}
.pop-info .pop-title{font-size:11px;font-weight:700;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:flex;align-items:center;gap:5px}
.pop-info .pop-title::before{content:'⚙';font-size:12px}
.pop-info .pr{display:flex;gap:7px;margin-bottom:5px;line-height:1.5}
.pop-info .pr:last-child{margin-bottom:0}
.pd{width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:6px}
.pd-g{background:var(--gm)}.pd-a{background:#F0C060}.pd-r{background:#F0AAAA}.pd-q{background:#F0AAAA}
.pop-q{background:#1C0A0A;color:#FFE4E4;border:1px solid rgba(240,170,170,.3)}
.pop-q .pop-title{font-size:11px;font-weight:700;color:rgba(255,200,200,.5);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:flex;align-items:center;gap:5px}
.pop-q .pop-title::before{content:'?';font-size:12px;color:var(--rb)}
.pop-q .pr{display:flex;gap:7px;margin-bottom:5px;line-height:1.5;color:#FFD0D0}
.pop-q .pr:last-child{margin-bottom:0}
.pop-q .note{font-size:10px;color:rgba(255,200,200,.45);margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,150,150,.15)}

/* ── Training table ── */
.tr-tbl{width:100%;border-collapse:collapse}
.tr-tbl th{font-size:10px;font-weight:700;color:var(--ink4);text-transform:uppercase;letter-spacing:.04em;padding:6px 10px;border-bottom:1px solid var(--bdr);text-align:left;white-space:nowrap}
.tr-tbl td{font-size:12px;padding:9px 10px;border-bottom:1px solid var(--bdr2);color:var(--ink2);vertical-align:middle}
.tr-tbl tr:last-child td{border-bottom:none}
.tr-role{font-weight:600}
.pill-stat{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:20px;font-size:10px;font-weight:700}
.ps-pend{background:var(--al);color:var(--am)}.ps-sched{background:var(--bl);color:var(--bm)}
.ps-prog{background:var(--pl);color:var(--pm)}.ps-done{background:var(--gl);color:var(--g)}
.bar-wrap{display:inline-flex;align-items:center;gap:5px}
.bar{height:5px;width:64px;background:var(--bdr2);border-radius:3px;overflow:hidden;display:inline-block}
.bar-fill{height:100%;border-radius:3px}
.bf-g{background:var(--gm)}.bf-a{background:#F0C060}.bf-r{background:var(--rb)}
.eligible-chip{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;background:var(--gl);color:var(--g)}

/* ── Filter bar ── */
.filter-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.filter-bar label{font-size:10px;font-weight:700;color:var(--ink4);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.filter-bar select,.filter-bar input[type=text]{font-family:'DM Sans',sans-serif;font-size:12px;padding:6px 10px;border:1px solid var(--bdr);border-radius:8px;background:var(--bg);color:var(--ink2);outline:none;transition:border-color .15s}
.filter-bar select:focus,.filter-bar input:focus{border-color:var(--gm);background:var(--s)}
.btn-clear{font-family:'DM Sans',sans-serif;font-size:11px;padding:5px 11px;border:1px solid var(--bdr);border-radius:7px;background:var(--s);color:var(--ink3);cursor:pointer}
.btn-clear:hover{background:var(--bg)}
.btn-pub-new{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;padding:6px 14px;border:none;border-radius:8px;background:var(--g);color:#fff;cursor:pointer;white-space:nowrap}
.btn-pub-new:hover{background:#0A5C46}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:700;white-space:nowrap}
.b-pub{background:var(--bl);color:var(--bm)}.b-tak{background:var(--gl);color:var(--g)}
.b-com{background:#E8E8ED;color:#555}.b-can{background:var(--rl);color:var(--rm)}
.b-wl{background:var(--al);color:var(--am)}.b-risk{background:#FF6B35;color:#fff}
.b-urg{background:#FF6B35;color:#fff}.b-std{background:var(--bg);color:var(--ink4);border:1px solid var(--bdr)}

/* ── DataTable overrides ── */
.dataTables_wrapper{font-family:'DM Sans',sans-serif}
.dataTables_length,.dataTables_filter{display:none}
.dataTables_info{font-size:11px;color:var(--ink4);padding:8px 2px}
.dt-pg-wrap{display:flex;justify-content:space-between;align-items:center}
.dt-pg-wrap .dataTables_info{display:none}
.dt-pg-wrap .dataTables_paginate{display:flex;gap:4px;padding:8px 0;justify-content:flex-end}
.dataTables_paginate .paginate_button{padding:4px 10px;border:1px solid var(--bdr)!important;border-radius:6px;font-size:12px;cursor:pointer;background:var(--s)!important;color:var(--ink2)!important;transition:background .12s}
.dataTables_paginate .paginate_button:hover{background:var(--bg)!important;color:var(--ink)!important}
.dataTables_paginate .paginate_button.current{background:var(--g)!important;color:#fff!important;border-color:var(--g)!important}
.dataTables_paginate .paginate_button.disabled{opacity:.4;cursor:default}
.dt-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:4px}
#dt-pag .dataTables_paginate{display:flex;gap:4px;padding:4px 0}
#dt-pag .paginate_button{padding:4px 10px;border:1px solid var(--bdr)!important;border-radius:6px;font-size:12px;cursor:pointer;background:var(--s)!important;color:var(--ink2)!important;transition:background .12s}
#dt-pag .paginate_button:hover{background:var(--bg)!important;color:var(--ink)!important}
#dt-pag .paginate_button.current{background:var(--g)!important;color:#fff!important;border-color:var(--g)!important}
#dt-pag .paginate_button.disabled{opacity:.4;cursor:default}
#jobTable{width:100%!important;border-collapse:collapse}
#jobTable thead th{font-size:10px;font-weight:700;color:var(--ink4);text-transform:uppercase;letter-spacing:.04em;padding:9px 12px;border-bottom:2px solid var(--bdr);background:var(--s);white-space:nowrap;cursor:pointer;user-select:none}
#jobTable thead th.sorting::after{content:' ↕';color:var(--bdr);font-size:9px}
#jobTable thead th.sorting_asc::after{content:' ↑';color:var(--gm);font-size:9px}
#jobTable thead th.sorting_desc::after{content:' ↓';color:var(--gm);font-size:9px}
#jobTable thead th.no-sort::after{content:''}
#jobTable tbody tr{border-bottom:1px solid var(--bdr2);transition:background .1s}
#jobTable tbody tr:hover{background:#FAFBFC}
#jobTable tbody td{font-size:12px;padding:10px 12px;color:var(--ink2);vertical-align:middle}
.job-id-cell{font-family:monospace;font-size:11px;color:var(--ink4);font-weight:600}
.type-cell{font-weight:500;font-size:12px}
.mj-name{font-size:12px;color:var(--ink2)}.mj-empty{font-size:11px;color:var(--ink4);font-style:italic}
.wl-chip{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:18px;padding:0 5px;border-radius:20px;background:var(--al);color:var(--am);font-size:10px;font-weight:700}
.wl-zero{font-size:11px;color:var(--ink4)}
.btn-manage{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;padding:4px 10px;border:1px solid var(--bdr);border-radius:6px;background:var(--s);color:var(--ink2);cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-manage:hover{background:var(--g);color:#fff;border-color:var(--g)}

/* ── Right panel ── */
.rp{padding:14px 15px}
.rp-title{font-size:10px;font-weight:700;color:var(--ink4);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;margin-top:14px}
.rp-title:first-child{margin-top:4px}
.risk-item{background:var(--rl);border:1px solid var(--rb);border-radius:9px;padding:9px 11px;display:flex;gap:8px;margin-bottom:6px}
.risk-dot{width:7px;height:7px;border-radius:50%;background:#FF6B35;flex-shrink:0;margin-top:4px}
.risk-id{font-family:monospace;font-size:10px;font-weight:700}
.risk-body{font-size:11px;color:var(--rm);line-height:1.45}
.rule-card{background:var(--bg);border:1px solid var(--bdr);border-radius:8px;padding:9px 11px;display:flex;gap:8px;margin-bottom:6px}
.rc-icon{font-size:13px;flex-shrink:0;margin-top:1px}
.rc-type{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:1px 5px;border-radius:20px;display:inline-block;margin-bottom:2px}
.rt-s{background:var(--bl);color:var(--bm)}.rt-b{background:var(--gl);color:var(--g)}
.rt-o{background:var(--al);color:var(--am)}.rt-q{background:var(--rl);color:var(--rm)}
.rc-title{font-size:11px;font-weight:600;color:var(--ink2);margin-bottom:1px}
.rc-text{font-size:11px;color:var(--ink4);line-height:1.4}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.46);z-index:500;display:flex;align-items:center;justify-content:center}
.modal-box{background:var(--s);border-radius:var(--rl2);width:580px;max-width:92vw;max-height:86vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-head{padding:16px 20px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;gap:10px}
.modal-head-title{font-size:14px;font-weight:600;flex:1}
.modal-close{background:none;border:1px solid var(--bdr);border-radius:6px;padding:4px 10px;cursor:pointer;font-size:12px;color:var(--ink3);font-family:'DM Sans',sans-serif}
.modal-body{flex:1;overflow-y:auto;padding:18px 20px}
.modal-footer{padding:12px 20px;border-top:1px solid var(--bdr);display:flex;gap:8px;align-items:center}
.m-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.m-info-box{background:var(--bg);border-radius:var(--r);padding:10px 12px}
.m-info-label{font-size:10px;font-weight:700;color:var(--ink4);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}
.m-info-val{font-size:13px;font-weight:500;color:var(--ink)}
.sect-title{font-size:11px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;margin-top:16px}
.sect-title:first-child{margin-top:0}
.slot-row{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:10px 13px;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.slot-num{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.sn-filled{background:var(--gl);color:var(--g)}.sn-empty{background:var(--bdr2);color:var(--ink4);border:1px dashed var(--bdr)}
.slot-name{font-size:13px;font-weight:500}.slot-meta{font-size:11px;color:var(--ink4)}
.wl-row{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:9px 12px;display:flex;align-items:center;gap:8px;margin-bottom:5px}
.wl-pos{width:20px;height:20px;border-radius:50%;background:var(--al);color:var(--am);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.wl-name{flex:1;font-size:12px;font-weight:500;color:var(--ink2)}.wl-time{font-size:10px;color:var(--ink4)}
.wl-btn{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:600;padding:3px 9px;border-radius:5px;cursor:pointer;border:1px solid}
.wl-confirm{background:var(--gl);color:var(--g);border-color:var(--gb)}.wl-remove{background:var(--rl);color:var(--rm);border-color:var(--rb)}
.banner{border-radius:var(--r);padding:10px 12px;font-size:12px;display:flex;gap:8px;line-height:1.5;margin-bottom:12px}
.bn-g{background:var(--gl);color:#0A5C46;border:1px solid var(--gb)}.bn-a{background:var(--al);color:var(--am);border:1px solid var(--ab)}
.bn-r{background:var(--rl);color:var(--rm);border:1px solid var(--rb)}
.btn-primary{background:var(--g);color:#fff;border:none;border-radius:var(--r);padding:8px 18px;font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif}
.btn-primary:hover{background:#0A5C46}
.btn-danger{background:var(--rm);color:#fff;border:none;border-radius:var(--r);padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif}
.btn-ghost{background:var(--s);border:1px solid var(--bdr);border-radius:var(--r);padding:8px 14px;font-size:13px;color:var(--ink2);cursor:pointer;font-family:'DM Sans',sans-serif}
.btn-ghost:disabled,.btn-primary:disabled,.btn-danger:disabled{opacity:.4;cursor:default}
.no-show-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:20px;font-size:10px;font-weight:700;background:var(--rl);color:var(--rm);border:1px solid var(--rb);margin-left:4px;vertical-align:middle}
.form-group{margin-bottom:14px}
.form-label{font-size:12px;font-weight:600;color:var(--ink2);margin-bottom:5px;display:block}
.form-sel{font-family:'DM Sans',sans-serif;font-size:13px;padding:8px 10px;border:1px solid var(--bdr);border-radius:var(--r);background:var(--bg);color:var(--ink);outline:none;width:100%;transition:border-color .15s}
.form-sel:focus{border-color:var(--gm);background:var(--s)}
.form-inp{font-family:'DM Sans',sans-serif;font-size:13px;padding:8px 10px;border:1px solid var(--bdr);border-radius:var(--r);background:var(--bg);color:var(--ink);outline:none;width:100%;transition:border-color .15s}
.form-inp:focus{border-color:var(--gm);background:var(--s)}
.filter-bar select,.filter-bar input{font-family:'DM Sans',sans-serif;font-size:12px;padding:6px 10px;border:1px solid var(--bdr);border-radius:8px;background:var(--bg);color:var(--ink2);outline:none;transition:border-color .15s}
.filter-bar select:focus,.filter-bar input:focus{border-color:var(--gm);background:var(--s)}