*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --bg:#0a0d12;--sur:#11151c;--sur2:#181e28;--sur3:#1e2535;
  --bor:#1e2535;--bor2:#2a3347;
  --txt:#e2e8f0;--txt2:#8a99b3;--txt3:#4a5568;
  --acc:#00c9a7;--acc2:#0096d6;--warn:#f59e0b;--dan:#ef4444;--ok:#10b981;--pur:#8b5cf6;--pnk:#ec4899;
  --mono:'IBM Plex Mono',monospace;--sans:'IBM Plex Sans',sans-serif;
  --shadow:rgba(0,0,0,.3);--shadow2:rgba(0,0,0,.15);
}
[data-theme="light"]{
  --bg:#f0f2f5;--sur:#ffffff;--sur2:#f7f8fa;--sur3:#ebedf0;
  --bor:#d4d8e0;--bor2:#c0c7d4;
  --txt:#1a1d23;--txt2:#4a5568;--txt3:#8a95a5;
  --acc:#009e85;--acc2:#0080b8;--warn:#d97706;--dan:#dc2626;--ok:#059669;--pur:#7c3aed;--pnk:#db2777;
  --shadow:rgba(0,0,0,.08);--shadow2:rgba(0,0,0,.04);
}
body{background:var(--bg);color:var(--txt);font-family:var(--sans);font-size:14px;min-height:100vh;display:flex;flex-direction:column;}
::-webkit-scrollbar{width:5px;height:5px;} ::-webkit-scrollbar-thumb{background:var(--bor2);border-radius:3px;}

/* HEADER */
header{background:var(--sur);border-bottom:1px solid var(--bor);padding:0 18px;display:flex;align-items:center;gap:10px;height:52px;position:sticky;top:0;z-index:200;flex-shrink:0;}
.logo{font-family:var(--mono);font-size:15px;font-weight:600;color:var(--acc);display:flex;align-items:center;gap:8px;}
.logo-box{width:26px;height:26px;background:var(--acc);border-radius:4px;display:flex;align-items:center;justify-content:center;color:#000;font-size:12px;font-weight:700;}
.hbadge{font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:3px;letter-spacing:.5px;font-weight:600;}
.hb1{background:rgba(0,201,167,.1);color:var(--acc);border:1px solid rgba(0,201,167,.25);}
.hb2{background:rgba(0,150,214,.1);color:var(--acc2);border:1px solid rgba(0,150,214,.25);}
.hright{display:flex;align-items:center;gap:8px;margin-left:auto;position:relative;}
.hbtn{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:5px;cursor:pointer;border:1px solid var(--bor2);background:transparent;color:var(--txt2);font-size:12px;font-family:var(--sans);transition:all .12s;}
.hbtn:hover{background:var(--sur2);color:var(--txt);}
.hbtn.prim{background:var(--acc);color:#000;border-color:var(--acc);}
.hbtn.prim:hover{background:#00b896;}
.ndot{width:7px;height:7px;border-radius:50%;background:var(--dan);display:none;}
.upill{display:flex;align-items:center;gap:7px;padding:4px 10px;border-radius:20px;background:var(--sur2);border:1px solid var(--bor2);cursor:pointer;}
.uav{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#000;}
.uname{font-size:12px;color:var(--txt2);}
.urole{font-family:var(--mono);font-size:9px;color:var(--acc);background:rgba(0,201,167,.1);padding:1px 5px;border-radius:3px;}

/* LAYOUT */
.app{display:flex;flex:1;height:calc(100vh - 52px);overflow:hidden;}

/* SIDEBAR */
.sb{width:210px;background:var(--sur);border-right:1px solid var(--bor);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;}
.sb-sec{padding:8px;border-bottom:1px solid var(--bor);}
.sb-lbl{font-family:var(--mono);font-size:9px;font-weight:600;color:var(--txt3);letter-spacing:1.5px;text-transform:uppercase;padding:0 6px;margin-bottom:4px;}
.ni{display:flex;align-items:center;gap:7px;padding:6px 8px;border-radius:5px;cursor:pointer;color:var(--txt2);font-size:12.5px;transition:all .12s;border:1px solid transparent;user-select:none;}
.ni:hover{background:var(--sur2);color:var(--txt);}
.ni.on{background:rgba(0,201,167,.08);color:var(--acc);border-color:rgba(0,201,167,.15);}
.nc{margin-left:auto;font-family:var(--mono);font-size:9px;padding:1px 5px;border-radius:8px;background:var(--sur2);border:1px solid var(--bor);color:var(--txt3);}
.ni.on .nc{background:rgba(0,201,167,.12);color:var(--acc);border-color:rgba(0,201,167,.2);}
.si{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:5px;cursor:pointer;font-size:12px;color:var(--txt2);transition:all .12s;user-select:none;}
.si:hover{background:var(--sur2);}
.si.on{background:var(--sur2);color:var(--txt);}
.sdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.sc{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--txt3);}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.topbar{background:var(--sur);border-bottom:1px solid var(--bor);padding:10px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0;}
.ptitle{font-size:16px;font-weight:600;}
.sw{display:flex;align-items:center;background:var(--sur2);border:1px solid var(--bor2);border-radius:5px;padding:6px 10px;gap:6px;width:240px;}
.sw input{background:none;border:none;outline:none;color:var(--txt);font-family:var(--sans);font-size:12.5px;width:100%;}
.sw input::placeholder{color:var(--txt3);}
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;border:none;font-family:var(--sans);transition:all .12s;}
.btn-p{background:var(--acc);color:#000;}
.btn-p:hover{background:#00b896;}
.btn-o{background:transparent;color:var(--txt2);border:1px solid var(--bor2);}
.btn-o:hover{background:var(--sur2);color:var(--txt);}
.btn-w{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.25);}
.btn-d{background:rgba(239,68,68,.1);color:var(--dan);border:1px solid rgba(239,68,68,.25);}

/* STATS */
.stats{display:flex;border-bottom:1px solid var(--bor);background:var(--sur);flex-shrink:0;}
.sp{flex:1;padding:8px 12px;border-right:1px solid var(--bor);cursor:pointer;transition:background .12s;}
.sp:last-child{border-right:none;}
.sp:hover{background:var(--sur2);}
.spl{font-family:var(--mono);font-size:8px;font-weight:600;color:var(--txt3);letter-spacing:1px;text-transform:uppercase;margin-bottom:3px;}
.spv{font-family:var(--mono);font-size:18px;font-weight:600;}
.sps{font-size:9px;color:var(--txt3);margin-top:1px;}

/* CONTENT */
.content{flex:1;overflow-y:auto;padding:12px;}
.frow{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;align-items:center;}
.fchip{font-family:var(--mono);font-size:10px;padding:4px 9px;border-radius:3px;cursor:pointer;border:1px solid var(--bor2);background:transparent;color:var(--txt2);transition:all .12s;}
.fchip:hover{border-color:var(--acc);color:var(--acc);}
.fchip.on{background:rgba(0,201,167,.1);border-color:var(--acc);color:var(--acc);}
.rcnt{font-family:var(--mono);font-size:10px;color:var(--txt3);margin-left:auto;}

/* CARDS */
.gl-list{display:flex;flex-direction:column;gap:4px;}
.glc{background:var(--sur);border:1px solid var(--bor);border-radius:7px;overflow:hidden;transition:border-color .12s;}
.glc:hover{border-color:var(--bor2);}
.glc.open{border-color:var(--bor2);}
.glc.rec{border-left:3px solid var(--acc2);}
.glc.asgn{border-left:3px solid var(--pur);}
.glc.ovd{border-left:3px solid var(--dan);}
.glh{padding:9px 14px;display:flex;align-items:center;gap:7px;cursor:pointer;user-select:none;}
.glid{font-family:var(--mono);font-size:11px;color:var(--acc2);font-weight:500;min-width:86px;}
.glsub{font-weight:500;font-size:13px;color:var(--txt);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fbdg{font-family:var(--mono);font-size:9px;padding:2px 5px;border-radius:3px;white-space:nowrap;}
.f-An{background:rgba(0,201,167,.08);color:var(--acc);border:1px solid rgba(0,201,167,.2);}
.f-Da{background:rgba(239,68,68,.08);color:var(--dan);border:1px solid rgba(239,68,68,.2);}
.f-Mo{background:rgba(245,158,11,.08);color:var(--warn);border:1px solid rgba(245,158,11,.2);}
.f-We{background:rgba(236,72,153,.08);color:var(--pnk);border:1px solid rgba(236,72,153,.2);}
.f-Bi{background:rgba(139,92,246,.08);color:var(--pur);border:1px solid rgba(139,92,246,.2);}
.f-ot{background:rgba(74,85,104,.1);color:var(--txt3);border:1px solid var(--bor);}
.sbdg{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.4px;padding:2px 7px;border-radius:3px;text-transform:uppercase;display:inline-flex;align-items:center;gap:3px;white-space:nowrap;}
.sbdg::before{content:'';width:4px;height:4px;border-radius:50%;background:currentColor;display:block;}
.s-met{background:rgba(16,185,129,.1);color:var(--ok);border:1px solid rgba(16,185,129,.2);}
.s-partial{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2);}
.s-gap{background:rgba(239,68,68,.1);color:var(--dan);border:1px solid rgba(239,68,68,.2);}
.s-na{background:rgba(74,85,104,.1);color:var(--txt3);border:1px solid var(--bor);}
.s-pending{background:rgba(139,92,246,.1);color:var(--pur);border:1px solid rgba(139,92,246,.2);}
.mav{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:#000;flex-shrink:0;}
.chev{color:var(--txt3);font-size:11px;transition:transform .2s;flex-shrink:0;}
.glc.open .chev{transform:rotate(180deg);}
.glb{display:none;border-top:1px solid var(--bor);}
.glc.open .glb{display:block;}

/* TABS */
.gtabs{display:flex;background:var(--sur2);border-bottom:1px solid var(--bor);overflow-x:auto;}
.gt{padding:8px 13px;font-size:11.5px;color:var(--txt2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .12s;white-space:nowrap;flex-shrink:0;}
.gt:hover{color:var(--txt);}
.gt.on{color:var(--acc);border-bottom-color:var(--acc);}
.tb{padding:14px;}
.tc{display:none;}
.tc.on{display:block;}

/* DETAIL */
.dg{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;}
.df{background:var(--sur2);border:1px solid var(--bor);border-radius:5px;padding:8px 10px;}
.df.full{grid-column:span 2;}
.dfl{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:1px;color:var(--txt3);text-transform:uppercase;margin-bottom:3px;}
.dfv{font-size:12.5px;color:var(--txt2);line-height:1.5;}
.dfv.hi{color:var(--txt);}
.reqt{font-size:12.5px;color:var(--txt);line-height:1.6;background:var(--sur2);border:1px solid var(--bor);border-radius:5px;padding:11px;margin-bottom:10px;}
.evid{font-size:12px;color:var(--txt2);line-height:1.6;background:rgba(0,150,214,.04);border:1px solid rgba(0,150,214,.15);border-radius:5px;padding:11px;margin-bottom:10px;}
.recbox{font-size:12px;color:var(--txt);line-height:1.6;background:rgba(0,201,167,.04);border:1px solid rgba(0,201,167,.15);border-radius:5px;padding:11px;margin-bottom:10px;}
.recbox-lbl{font-family:var(--mono);font-size:9px;color:var(--acc);letter-spacing:1px;text-transform:uppercase;margin-bottom:5px;}
.sc-row{display:flex;gap:5px;align-items:center;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px solid var(--bor);}
.sc-lbl{font-family:var(--mono);font-size:9px;color:var(--txt3);}
.scb{font-family:var(--mono);font-size:10px;padding:5px 10px;border-radius:4px;cursor:pointer;border:1px solid var(--bor2);background:transparent;color:var(--txt2);transition:all .12s;}
.scb:hover{background:var(--sur);}
.scb.sel-met{background:rgba(16,185,129,.15);border-color:var(--ok);color:var(--ok);}
.scb.sel-partial{background:rgba(245,158,11,.15);border-color:var(--warn);color:var(--warn);}
.scb.sel-gap{background:rgba(239,68,68,.15);border-color:var(--dan);color:var(--dan);}
.scb.sel-na{background:rgba(74,85,104,.2);border-color:var(--txt3);color:var(--txt3);}

/* ASSIGN */
.ap{background:var(--sur2);border:1px solid var(--bor);border-radius:6px;padding:12px;margin-bottom:10px;}
.ap-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.ap-t{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:1px;color:var(--txt3);text-transform:uppercase;}
.ar{display:flex;gap:7px;align-items:center;flex-wrap:wrap;}
.asel{background:var(--sur);border:1px solid var(--bor2);border-radius:5px;padding:6px 10px;color:var(--txt);font-family:var(--sans);font-size:12px;outline:none;flex:1;min-width:130px;}
.asel:focus{border-color:var(--acc);}
.dinp{background:var(--sur);border:1px solid var(--bor2);border-radius:5px;padding:6px 10px;color:var(--txt);font-family:var(--sans);font-size:12px;outline:none;}
.dinp:focus{border-color:var(--acc);}
.ca{display:flex;gap:7px;margin-top:8px;flex-wrap:wrap;}
.achip{display:flex;align-items:center;gap:5px;background:var(--sur);border:1px solid var(--bor2);border-radius:20px;padding:3px 9px;font-size:11.5px;}
.achip-primary{border-color:var(--acc);background:rgba(0,201,167,.06);}
.ack-blocked{opacity:.55;}
.ab-blocked{background:#fef3c7;color:#92400e;font-size:10px;padding:2px 7px;border-radius:9px;white-space:nowrap;}
.ack-blocked-btn{opacity:.5;cursor:not-allowed !important;}
.achip-n{color:var(--txt2);}
.achip-r{font-family:var(--mono);font-size:9px;color:var(--txt3);}
.achip-x{color:var(--txt3);cursor:pointer;margin-left:3px;}
.achip-x:hover{color:var(--dan);}
.dued{font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:3px;}
.dued.ovd{color:var(--dan);background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);}
.dued.ok{color:var(--ok);background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2);}
.dued.warn{color:var(--warn);background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);}

/* ACK */
.ack-sec{margin-top:10px;padding-top:10px;border-top:1px solid var(--bor);}
.ack-t{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:1px;color:var(--txt3);text-transform:uppercase;margin-bottom:7px;}
.acklist{display:flex;flex-direction:column;gap:4px;}
.ackitem{display:flex;align-items:center;gap:7px;background:var(--sur);border:1px solid var(--bor);border-radius:5px;padding:7px 10px;font-size:12px;}
.ackav{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#000;flex-shrink:0;}
.ackname{flex:1;color:var(--txt2);}
.acktime{font-family:var(--mono);font-size:9px;color:var(--txt3);}
.ackbdg{font-family:var(--mono);font-size:9px;padding:2px 5px;border-radius:3px;}
.ab-done{background:rgba(16,185,129,.1);color:var(--ok);border:1px solid rgba(16,185,129,.2);}
.ab-pend{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2);}
.ackbtn{width:100%;margin-top:7px;padding:7px;background:rgba(0,201,167,.08);border:1px solid rgba(0,201,167,.25);border-radius:5px;color:var(--acc);font-family:var(--mono);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s;}
.ackbtn:hover{background:rgba(0,201,167,.15);}
.ackbtn:disabled{opacity:.4;cursor:default;}

/* REMINDERS */
.rsec{margin-top:10px;padding-top:10px;border-top:1px solid var(--bor);}
.rlist{display:flex;flex-direction:column;gap:4px;margin-top:6px;}
.ritem{display:flex;align-items:center;gap:7px;background:var(--sur);border:1px solid var(--bor);border-radius:5px;padding:7px 10px;font-size:12px;}
.rtxt{flex:1;color:var(--txt2);}
.rdue{font-family:var(--mono);font-size:9px;color:var(--txt3);}
.rdel{color:var(--txt3);cursor:pointer;}
.rdel:hover{color:var(--dan);}
.radd{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap;}
.rinp{flex:1;min-width:130px;background:var(--sur);border:1px solid var(--bor2);border-radius:5px;padding:6px 10px;color:var(--txt);font-family:var(--sans);font-size:12px;outline:none;}
.rinp:focus{border-color:var(--warn);}

/* RECORD TEMPLATE */
.rt{background:var(--sur2);border:1px solid var(--bor);border-radius:6px;padding:13px;}
.rt-t{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--txt3);margin-bottom:10px;}
.rtg{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.rtf{display:flex;flex-direction:column;gap:3px;}
.rtf.full{grid-column:span 2;}
.rtf label{font-size:10.5px;color:var(--txt3);}
.rti{background:var(--sur);border:1px solid var(--bor2);border-radius:4px;padding:6px 9px;color:var(--txt);font-family:var(--sans);font-size:12px;outline:none;width:100%;}
.rti:focus{border-color:var(--acc);}
textarea.rti{min-height:65px;resize:vertical;}
.rta{display:flex;gap:7px;margin-top:10px;}
.srlist{margin-top:12px;border-top:1px solid var(--bor);padding-top:9px;}
.srl-lbl{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:1px;color:var(--txt3);margin-bottom:7px;text-transform:uppercase;}
.sri{background:var(--sur);border:1px solid var(--bor);border-radius:5px;padding:9px 11px;margin-bottom:5px;font-size:12px;}
.sri-h{display:flex;align-items:center;gap:7px;margin-bottom:4px;}
.sri-d{font-family:var(--mono);font-size:10px;color:var(--txt3);}
.sri-b{color:var(--acc2);font-weight:500;}
.sri-s{font-family:var(--mono);font-size:9px;padding:2px 5px;border-radius:3px;}
.rs-met{background:rgba(16,185,129,.1);color:var(--ok);border:1px solid rgba(16,185,129,.2);}
.rs-partial{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2);}
.rs-gap{background:rgba(239,68,68,.1);color:var(--dan);border:1px solid rgba(239,68,68,.2);}
.sri-body{color:var(--txt2);line-height:1.5;}

/* DOCUMENT UPLOAD */
.doc-sec{margin-bottom:12px;}
.drop-area{border:2px dashed var(--bor2);border-radius:7px;padding:20px;text-align:center;cursor:pointer;transition:all .15s;background:var(--sur2);}
.drop-area:hover,.drop-area.drag{border-color:var(--acc);background:rgba(0,201,167,.04);}
.drop-icon{font-size:24px;margin-bottom:6px;}
.drop-text{font-size:12.5px;color:var(--txt2);margin-bottom:4px;}
.drop-sub{font-size:11px;color:var(--txt3);}
.doc-list{display:flex;flex-direction:column;gap:5px;margin-top:10px;}
.docitem{display:flex;align-items:center;gap:8px;background:var(--sur);border:1px solid var(--bor);border-radius:5px;padding:8px 11px;}
.doc-icon{font-size:16px;}
.doc-info{flex:1;}
.doc-name{font-size:13px;color:var(--txt);font-weight:500;}
.doc-meta{font-size:10.5px;color:var(--txt3);margin-top:1px;}
.doc-status{font-family:var(--mono);font-size:9px;padding:2px 6px;border-radius:3px;}
.ds-pending{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2);}
.ds-approved{background:rgba(16,185,129,.1);color:var(--ok);border:1px solid rgba(16,185,129,.2);}
.ds-review{background:rgba(139,92,246,.1);color:var(--pur);border:1px solid rgba(139,92,246,.2);}
.ds-rejected{background:rgba(239,68,68,.1);color:var(--dan);border:1px solid rgba(239,68,68,.2);}
.ds-superseded{background:rgba(120,120,120,.08);color:#999;border:1px solid rgba(120,120,120,.2);}
.ds-retired{background:rgba(120,120,120,.08);color:#888;border:1px solid rgba(120,120,120,.2);text-decoration:line-through;}
.ds-review-due{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2);}
.instr-active{background:rgba(16,185,129,.1);color:var(--ok);border:1px solid rgba(16,185,129,.2);}
.instr-oos{background:rgba(239,68,68,.1);color:var(--dan);border:1px solid rgba(239,68,68,.2);}
.instr-decom{background:rgba(120,120,120,.08);color:#888;border:1px solid rgba(120,120,120,.2);text-decoration:line-through;}
.pm-ok{color:var(--ok);font-weight:600;}
.pm-due-soon{color:var(--warn);font-weight:600;}
.pm-overdue{color:var(--dan);font-weight:600;}
.instr-card{background:var(--sur);border:1px solid var(--bor);border-radius:10px;padding:14px 16px;margin-bottom:10px;transition:border-color .15s;}
.instr-card:hover{border-color:var(--acc);}
.instr-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.instr-card-name{font-weight:600;font-size:14px;color:var(--txt);flex:1;}
.instr-card-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px 16px;font-size:12px;color:var(--txt2);}
.instr-card-meta b{color:var(--txt);font-weight:500;}
.instr-card-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--bor);}
/* ── DOA (Delegation of Authority) ── */
.doa-card{background:var(--sur);border:1px solid var(--bor);border-radius:10px;padding:14px 16px;margin-bottom:10px;transition:border-color .15s;}
.doa-card:hover{border-color:var(--acc);}
.doa-card.doa-expiring{border-left:3px solid var(--warn);}
.doa-card.doa-expired-card{border-left:3px solid var(--dan);opacity:.85;}
.doa-card.doa-revoked-card{border-left:3px solid #888;opacity:.7;}
.doa-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.doa-card-title{font-weight:600;font-size:14px;color:var(--txt);flex:1;}
.doa-card-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px 16px;font-size:12px;color:var(--txt2);}
.doa-card-meta b{color:var(--txt);font-weight:500;}
.doa-card-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--bor);}
.doa-status{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;letter-spacing:.3px;}
.doa-status-active{background:rgba(16,185,129,.12);color:var(--ok);}
.doa-status-expired{background:rgba(239,68,68,.12);color:var(--dan);}
.doa-status-revoked{background:rgba(120,120,120,.15);color:#888;}
.doa-status-pending{background:rgba(245,158,11,.12);color:var(--warn);}
.doa-arrow{font-size:16px;color:var(--acc);font-weight:700;margin:0 6px;}
.doa-timeline{height:6px;background:var(--sur2);border-radius:3px;position:relative;overflow:hidden;margin:8px 0;}
.doa-timeline-fill{height:100%;border-radius:3px;transition:width .3s;}
.doa-audit-row{display:flex;gap:10px;padding:6px 0;border-bottom:1px solid var(--bor);font-size:12px;color:var(--txt2);}
.doa-audit-row:last-child{border-bottom:none;}
.doc-actions{display:flex;gap:5px;align-items:center;}
.doc-act-btn{font-size:11px;padding:4px 8px;border-radius:4px;cursor:pointer;border:1px solid var(--bor2);background:transparent;color:var(--txt2);transition:all .12s;}
.doc-act-btn:hover{background:var(--sur2);color:var(--txt);}
.doc-act-btn.approve{color:var(--ok);border-color:rgba(16,185,129,.3);}
.doc-act-btn.approve:hover{background:rgba(16,185,129,.1);}
.doc-act-btn.reject{color:var(--dan);border-color:rgba(239,68,68,.3);}
.doc-act-btn.reject:hover{background:rgba(239,68,68,.1);}
.chain-badge{font-family:var(--mono);font-size:9px;color:var(--pur);background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.2);padding:2px 6px;border-radius:3px;}

/* SOP */
.soplist{display:flex;flex-direction:column;gap:4px;}
.sopitem{display:flex;align-items:center;gap:7px;background:var(--sur);border:1px solid var(--bor);border-radius:5px;padding:7px 10px;font-size:12px;}
.sopitem-placeholder{background:rgba(240,180,41,.04);border-color:rgba(240,180,41,.15);}
.sop-name{flex:1;color:var(--txt2);}
.sop-type{font-family:var(--mono);font-size:9px;color:var(--txt3);background:var(--sur2);border:1px solid var(--bor);padding:1px 5px;border-radius:3px;}
.sop-view{font-size:11px;color:var(--acc2);cursor:pointer;}
.sop-view:hover{text-decoration:underline;}
.sop-add{width:100%;margin-top:6px;padding:7px;background:transparent;border:1px dashed var(--bor2);border-radius:5px;color:var(--txt3);font-size:12px;cursor:pointer;font-family:var(--sans);transition:all .12s;}
.sop-add:hover{border-color:var(--acc);color:var(--acc);}

/* AUDIT */
.alog{display:flex;flex-direction:column;}
.alr{display:flex;gap:7px;padding:6px 0;border-bottom:1px solid var(--bor);font-size:11.5px;align-items:flex-start;}
.alr:last-child{border-bottom:none;}
.adot{width:6px;height:6px;border-radius:50%;margin-top:4px;flex-shrink:0;}
.ad-g{background:var(--ok);}.ad-b{background:var(--acc2);}.ad-y{background:var(--warn);}.ad-r{background:var(--dan);}.ad-p{background:var(--pur);}
.at{font-family:var(--mono);font-size:9px;color:var(--txt3);min-width:115px;}
.au{color:var(--acc2);min-width:100px;font-weight:500;}
.aa{color:var(--txt2);flex:1;}
.audinp{flex:1;background:var(--sur2);border:1px solid var(--bor2);border-radius:5px;padding:6px 10px;color:var(--txt);font-family:var(--sans);font-size:12px;outline:none;}
.audinp:focus{border-color:var(--acc);}

/* GLOBAL DOCS PAGE */
.docs-page{display:none;flex:1;flex-direction:column;overflow:hidden;}
.docs-page.on{display:flex;}
.gl-page{display:flex;flex-direction:column;flex:1;overflow:hidden;}
.gl-page.off{display:none;}

/* APPROVAL CHAIN MANAGER */
.chain-manager{background:var(--sur);border:1px solid var(--bor);border-radius:8px;padding:16px;margin-bottom:14px;}
.cm-t{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:1px;color:var(--txt3);text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;}
.chain-steps{display:flex;align-items:center;gap:0;flex-wrap:wrap;margin-bottom:14px;}
.chain-step{display:flex;align-items:center;}
.cs-box{background:var(--sur2);border:1px solid var(--bor2);border-radius:6px;padding:8px 12px;display:flex;align-items:center;gap:7px;min-width:130px;}
.cs-num{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--acc2);background:rgba(0,150,214,.1);width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cs-info{flex:1;}
.cs-name{font-size:12px;font-weight:500;}
.cs-role{font-size:10px;color:var(--txt3);font-family:var(--mono);}
.cs-arrow{color:var(--txt3);padding:0 6px;font-size:13px;}
.cs-remove{color:var(--txt3);cursor:pointer;font-size:11px;margin-left:4px;}
.cs-remove:hover{color:var(--dan);}

/* GLOBAL DOCS LIST */
.gdoc-list{display:flex;flex-direction:column;gap:6px;}
.gdoc{background:var(--sur);border:1px solid var(--bor);border-radius:7px;padding:13px 15px;}
.gdoc-h{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.gdoc-icon{font-size:20px;}
.gdoc-name{font-size:14px;font-weight:600;flex:1;}
.gdoc-type{font-family:var(--mono);font-size:9px;padding:2px 6px;border-radius:3px;background:var(--sur2);border:1px solid var(--bor);color:var(--txt3);}
.gdoc-ver{font-family:var(--mono);font-size:10px;color:var(--acc2);}
.gdoc-meta{font-size:11.5px;color:var(--txt3);margin-bottom:8px;}
.gdoc-chain{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:8px;}
.chain-user{display:flex;align-items:center;gap:4px;background:var(--sur2);border:1px solid var(--bor2);border-radius:20px;padding:3px 8px;font-size:11px;}
.chain-user.done{border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.06);}
.chain-user.active{border-color:rgba(0,150,214,.3);background:rgba(0,150,214,.06);}
.chain-user.wait{opacity:.5;}
.chain-arrow{color:var(--txt3);font-size:10px;}
.gdoc-acts{display:flex;gap:6px;}
.notif-banner{background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.2);border-radius:6px;padding:10px 14px;margin-bottom:10px;display:flex;align-items:center;gap:10px;font-size:12.5px;}
.nb-icon{font-size:18px;}
.nb-text{flex:1;color:var(--txt);}
.nb-dismiss{color:var(--txt3);cursor:pointer;font-size:13px;}
.nb-dismiss:hover{color:var(--txt);}

/* MODAL */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s;}
.mo.on{opacity:1;pointer-events:all;}
.mbox{background:var(--sur);border:1px solid var(--bor2);border-radius:10px;width:100%;max-width:580px;max-height:88vh;overflow-y:auto;transform:translateY(16px);transition:transform .2s;}
.mo.on .mbox{transform:translateY(0);}
.mh{padding:14px 18px;border-bottom:1px solid var(--bor);display:flex;align-items:center;gap:10px;}
.mhtit{font-size:16px;font-weight:600;flex:1;}
.mclose{width:26px;height:26px;border-radius:5px;background:var(--sur2);border:1px solid var(--bor);color:var(--txt2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;}
.mbody{padding:18px;}
.mfooter{padding:12px 18px;border-top:1px solid var(--bor);display:flex;justify-content:flex-end;gap:7px;}
.fg{display:flex;flex-direction:column;gap:4px;margin-bottom:11px;}
.fg label{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--txt3);}
.fc{background:var(--sur2);border:1px solid var(--bor2);border-radius:5px;padding:8px 10px;color:var(--txt);font-family:var(--sans);font-size:12.5px;outline:none;width:100%;}
.fc:focus{border-color:var(--acc);}
.ugrid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.ucard{background:var(--sur2);border:1px solid var(--bor2);border-radius:7px;padding:9px 11px;cursor:pointer;transition:all .12s;}
.ucard:hover,.ucard.sel{border-color:var(--acc);background:rgba(0,201,167,.06);}
.uc-top{display:flex;align-items:center;gap:7px;margin-bottom:5px;}
.uca{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#000;}
.uc-name{font-weight:500;font-size:13px;}
.uc-role{font-family:var(--mono);font-size:9px;color:var(--txt3);margin-bottom:2px;}
.uc-dept{font-size:11px;color:var(--txt3);}

/* NOTIF PANEL */
.np{position:absolute;top:52px;right:0;width:340px;background:var(--sur);border:1px solid var(--bor2);border-radius:8px;box-shadow:0 8px 32px var(--shadow);z-index:250;display:none;}
.np.on{display:block;}
.nph{padding:11px 15px;border-bottom:1px solid var(--bor);display:flex;align-items:center;justify-content:space-between;}
.npt{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--txt);}
.npc{font-size:11px;color:var(--txt3);cursor:pointer;}
.npc:hover{color:var(--acc);}
.npl{max-height:360px;overflow-y:auto;}
.npi{padding:9px 15px;border-bottom:1px solid var(--bor);cursor:pointer;transition:background .12s;}
.npi:hover{background:var(--sur2);}
.npi:last-child{border-bottom:none;}
.ni-top2{display:flex;align-items:center;gap:5px;margin-bottom:2px;}
.ni-ico{font-size:13px;}
.ni-tit{font-size:12.5px;font-weight:500;flex:1;}
.ni-time{font-family:var(--mono);font-size:9px;color:var(--txt3);}
.ni-bd{font-size:11.5px;color:var(--txt3);}
.ndot2{width:6px;height:6px;border-radius:50%;background:var(--acc);}

/* PAGINATION */
.pgn{display:flex;align-items:center;gap:5px;padding:11px 0;justify-content:center;}
.pgb{font-family:var(--mono);font-size:11px;padding:5px 9px;border-radius:4px;cursor:pointer;border:1px solid var(--bor2);background:transparent;color:var(--txt2);}
.pgb:hover:not(:disabled){background:var(--sur2);color:var(--txt);}
.pgb:disabled{opacity:.3;cursor:default;}
.pgb.on{background:rgba(0,201,167,.1);border-color:var(--acc);color:var(--acc);}
.pginfo{font-family:var(--mono);font-size:10px;color:var(--txt3);padding:0 5px;}

/* TOAST */
.toast{position:fixed;bottom:20px;right:20px;background:var(--sur2);border:1px solid var(--bor2);border-left:3px solid var(--acc);border-radius:7px;padding:10px 13px;font-size:12.5px;z-index:999;transform:translateY(80px);opacity:0;transition:all .25s;max-width:300px;pointer-events:none;}
.toast.on{transform:translateY(0);opacity:1;}
.toast-t{font-weight:600;font-size:10px;font-family:var(--mono);margin-bottom:2px;}
.toast.tg .toast-t{color:var(--acc);}
.toast.tb .toast-t{color:var(--acc2);}
.toast.tw .toast-t{color:var(--warn);}
.toast.tr .toast-t{color:var(--dan);}

.empty{text-align:center;padding:50px 20px;color:var(--txt3);}
.sep{height:1px;background:var(--bor);margin:10px 0;}
.file-input-hidden{display:none;}

/* GUIDELINE EDIT/ADD MODAL */
.gl-edit-btn{
  cursor:pointer;
  padding:4px 10px;
  font-size:11px;
  font-weight:600;
  border-radius:5px;
  border:1px solid rgba(240,180,41,.4);
  background:rgba(240,180,41,.1);
  color:var(--acc);
  font-family:var(--mono);
  transition:all .15s;
  white-space:nowrap;
  margin-left:4px;
}
.gl-edit-btn:hover{background:rgba(240,180,41,.2);border-color:rgba(240,180,41,.6);color:var(--txt);}
#modal-gl{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;display:flex;align-items:center;justify-content:center;}
#modal-gl.off{display:none;}
.gl-modal-body .fc{width:100%;box-sizing:border-box;background:var(--sur2);border:1px solid var(--bor);border-radius:5px;padding:6px 9px;color:var(--txt);font-size:12px;}
.gl-modal-body .fc:focus{outline:none;border-color:var(--acc);}
.gl-modal-body textarea.fc{resize:vertical;}
.gl-modal-box{background:var(--sur);border:1px solid var(--bor2);border-radius:10px;width:720px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;}
.gl-modal-hd{padding:16px 20px;border-bottom:1px solid var(--bor);display:flex;align-items:center;gap:10px;}
.gl-modal-hd h2{font-size:15px;flex:1;}
.gl-modal-hd .badge{font-family:var(--mono);font-size:9px;padding:2px 7px;border-radius:3px;background:rgba(139,92,246,.15);color:var(--pur);border:1px solid rgba(139,92,246,.25);}
.gl-modal-body{padding:20px;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.gl-modal-body .fg-full{grid-column:1/-1;}
.gl-modal-body .fg label{font-size:11px;color:var(--txt2);margin-bottom:4px;display:block;font-weight:500;}
.gl-modal-body .fg input,.gl-modal-body .fg select,.gl-modal-body .fg textarea{width:100%;background:var(--sur2);border:1px solid var(--bor2);border-radius:5px;padding:7px 10px;color:var(--txt);font-family:var(--sans);font-size:13px;outline:none;transition:border .12s;}
.gl-modal-body .fg input:focus,.gl-modal-body .fg select:focus,.gl-modal-body .fg textarea:focus{border-color:var(--acc);}
.gl-modal-body .fg textarea{resize:vertical;min-height:70px;}
.gl-modal-ft{padding:14px 20px;border-top:1px solid var(--bor);display:flex;justify-content:flex-end;gap:8px;}


/* NOTIFICATION ITEMS - CLICKABLE */
.npi{padding:10px 14px;border-bottom:1px solid var(--bor);cursor:pointer;transition:background .1s;}
.npi:hover{background:var(--sur2);}
.npi:last-child{border-bottom:none;}

/* FILE VIEWER IN DOC MODAL */
.file-viewer-frame{width:100%;height:400px;border:none;background:#fff;}
.file-viewer-img{max-width:100%;max-height:380px;display:block;margin:0 auto;padding:10px;}
.file-dl-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--sur2);border-bottom:1px solid var(--bor);}
.file-dl-bar a{color:var(--acc);font-size:12px;text-decoration:none;display:flex;align-items:center;gap:4px;}
.file-dl-bar a:hover{text-decoration:underline;}

/* CHECKLIST CUSTOM ITEM */
.cl-item{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--sur2);border:1px solid var(--bor);border-radius:5px;font-size:12.5px;}
.cl-item .cl-badge{font-family:var(--mono);font-size:9px;padding:1px 5px;border-radius:3px;background:rgba(0,201,167,.1);color:var(--acc);border:1px solid rgba(0,201,167,.2);}
.cl-item .cl-badge.custom{background:rgba(139,92,246,.1);color:var(--pur);border-color:rgba(139,92,246,.2);}
.cl-item .cl-del{margin-left:auto;color:var(--dan);cursor:pointer;font-size:13px;opacity:.6;transition:opacity .12s;}
.cl-item .cl-del:hover{opacity:1;}


/* ── Records Page ── */

/* ── GUIDELINE QUICK ACCESS PANEL ── */
.gl-quick-access{margin:0 0 0 0;padding:10px 14px;background:var(--bg2);border-bottom:1px solid var(--bor);font-size:12px;}
.qa-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--bor);}
.qa-section{margin-bottom:8px;}
.qa-section:last-child{margin-bottom:0;}
.qa-section-lbl{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.8px;color:var(--txt3);text-transform:uppercase;margin-bottom:5px;display:flex;align-items:center;gap:6px;}
.qa-count{background:var(--sur);border:1px solid var(--bor);border-radius:10px;padding:1px 6px;font-size:9px;color:var(--txt2);}
.qa-items{display:flex;flex-direction:column;gap:3px;}
.qa-rec-item{display:flex;align-items:center;gap:7px;padding:4px 8px;background:var(--sur);border:1px solid var(--bor);border-radius:5px;cursor:pointer;transition:border-color .15s;}
.qa-rec-item:hover{border-color:var(--acc);}
.qa-rec-date{font-family:var(--mono);font-size:10px;color:var(--txt3);white-space:nowrap;}
.qa-rec-by{font-size:11px;color:var(--acc2);font-weight:500;white-space:nowrap;}
.qa-att-badge{font-size:10px;background:rgba(240,180,41,.1);border:1px solid rgba(240,180,41,.2);color:var(--acc);padding:1px 5px;border-radius:3px;white-space:nowrap;}
.qa-rec-preview{font-size:11px;color:var(--txt2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.qa-doc-item{display:flex;align-items:center;gap:7px;padding:4px 8px;background:var(--sur);border:1px solid var(--bor);border-radius:5px;}
.qa-doc-name{font-size:12px;font-weight:500;flex:1;}
.qa-file-link{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-family:var(--mono);background:var(--sur);border:1px solid var(--bor);padding:3px 8px;border-radius:4px;color:var(--acc);text-decoration:none;transition:border-color .15s;}
.qa-file-link:hover{border-color:var(--acc);background:rgba(0,150,214,.06);}
.qa-file-nourl{color:var(--txt3);cursor:default;}

.rec-page,.rca-page,.quality-page,.safety-page,.edu-page,.hr-page{display:none;flex:1;flex-direction:column;overflow:hidden;}
.rec-page.active,.rca-page.active,.quality-page.active,.safety-page.active,.edu-page.active,.hr-page.active{display:flex;}
.page-main{flex-direction:column;flex:1;overflow:hidden;}
.page-main .topbar{flex-shrink:0;}
.page-main .content{flex:1;overflow-y:auto;padding:20px 24px;}
.rec-table{width:100%;border-collapse:collapse;font-size:12.5px;}
.rec-table th{background:var(--sur2);padding:8px 10px;text-align:left;font-size:11px;font-family:var(--mono);color:var(--txt3);border-bottom:1px solid var(--bor);position:sticky;top:0;}
.rec-table td{padding:8px 10px;border-bottom:1px solid var(--bor);vertical-align:top;}
.rec-table tr:hover td{background:var(--sur2);}
.rec-card{background:var(--sur);border:1px solid var(--bor);border-radius:8px;padding:14px 16px;margin-bottom:10px;}
.rec-card-h{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap;}
.rec-card-title{font-weight:600;font-size:13px;color:var(--txt);flex:1;}
.rec-card-meta{font-size:11px;color:var(--txt3);}
/* ── CAPA Page ── */
.capa-item{background:var(--sur);border:1px solid var(--bor);border-radius:8px;padding:14px 16px;margin-bottom:10px;}
.capa-h{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap;}
.capa-badge{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:600;font-family:var(--mono);}
.capa-open{background:rgba(239,68,68,.1);color:var(--dan);border:1px solid rgba(239,68,68,.2);}
.capa-progress{background:rgba(245,158,11,.1);color:var(--warn);border:1px solid rgba(245,158,11,.2);}
.capa-closed{background:rgba(16,185,129,.1);color:var(--ok);border:1px solid rgba(16,185,129,.2);}
.capa-form{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;}
.capa-form .fg-full{grid-column:1/-1;}
/* ── Quality/Safety Shared ── */
.qs-kpi-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px;}
.qs-kpi{background:var(--sur);border:1px solid var(--bor);border-radius:8px;padding:14px;text-align:center;}
.qs-kpi-val{font-size:28px;font-weight:700;color:var(--acc);font-family:var(--mono);}
.qs-kpi-lbl{font-size:11px;color:var(--txt3);margin-top:4px;}
.qs-section{background:var(--sur);border:1px solid var(--bor);border-radius:8px;margin-bottom:14px;}
.qs-section-h{padding:12px 16px;border-bottom:1px solid var(--bor);font-weight:600;font-size:13px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;}
.qs-section-body{padding:14px 16px;}
.qs-entry{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--bor);}
.qs-entry:last-child{border-bottom:none;}
.qs-entry-main{flex:1;}
.qs-entry-title{font-size:13px;font-weight:600;color:var(--txt);}
.qs-entry-meta{font-size:11px;color:var(--txt3);margin-top:2px;}
/* ── Education Page ── */
.edu-card{background:var(--sur);border:1px solid var(--bor);border-radius:8px;padding:14px 16px;margin-bottom:10px;}
.edu-track{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.edu-pill{font-size:11px;padding:3px 9px;border-radius:10px;background:rgba(139,92,246,.1);color:var(--pur);border:1px solid rgba(139,92,246,.2);}
.edu-progress-bar{height:6px;background:var(--bor);border-radius:3px;overflow:hidden;margin-top:6px;}
.edu-progress-fill{height:100%;background:var(--acc);border-radius:3px;transition:width .4s;}
/* ── HR Page ── */
.hr-emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:20px;}
.hr-emp-card{background:var(--sur);border:1px solid var(--bor);border-radius:10px;overflow:hidden;}
.hr-emp-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--bor);}
.hr-emp-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:15px;flex-shrink:0;}
.hr-emp-name{font-weight:600;font-size:13px;color:var(--txt);}
.hr-emp-role{font-size:11px;color:var(--txt3);}
.hr-emp-body{padding:12px 16px;}
.hr-emp-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0;color:var(--txt2);}
.hr-emp-row span:last-child{color:var(--txt);font-weight:500;}
.hr-emp-actions{padding:10px 16px;border-top:1px solid var(--bor);display:flex;gap:6px;}
/* ── Attach evidence in record ── */
.rec-attach-zone{border:1px dashed var(--bor2);border-radius:6px;padding:10px 14px;font-size:12px;color:var(--txt3);cursor:pointer;text-align:center;margin-top:8px;transition:.2s;}
.rec-attach-zone:hover{border-color:var(--acc);color:var(--acc);}
.rec-attach-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}
.rec-attach-item{display:flex;align-items:center;gap:5px;background:var(--sur2);border:1px solid var(--bor);border-radius:4px;padding:3px 8px;font-size:11px;}
.rec-attach-rm{cursor:pointer;color:var(--dan);margin-left:2px;font-size:12px;}
/* ── Inventory Module ── */
.inv-card{background:var(--sur);border:1px solid var(--bor);border-radius:8px;padding:14px 16px;margin-bottom:10px;transition:.15s;}
.inv-card:hover{border-color:var(--acc);box-shadow:0 1px 6px rgba(0,0,0,.06);}
.inv-card-hd{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.inv-card-hd h3{margin:0;font-size:14px;font-weight:600;color:var(--txt);flex:1;}
.inv-stock-bar{height:6px;background:var(--sur2);border-radius:3px;overflow:hidden;margin:6px 0;}
.inv-stock-fill{height:100%;border-radius:3px;transition:width .3s;}
.inv-lot-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;}
.inv-lot-active{background:#dcfce7;color:#166534;}
.inv-lot-expired{background:#fee2e2;color:#991b1b;}
.inv-lot-recalled{background:#fef3c7;color:#92400e;}
.inv-lot-depleted{background:var(--sur2);color:var(--txt3);}
.inv-cat-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;background:var(--sur2);color:var(--txt2);}
.inv-status-active{color:var(--ok);} .inv-status-inactive{color:var(--txt3);} .inv-status-discontinued{color:var(--dan);}
.inv-low{border-left:3px solid var(--dan);} .inv-reorder{border-left:3px solid var(--warn);}
.inv-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--txt2);margin:6px 0;}
.inv-meta span{display:flex;align-items:center;gap:3px;}
.inv-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;}
.inv-actions button{font-size:11px;padding:3px 10px;}
/* ── Theme Toggle ── */
.theme-toggle{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;font-size:13px;color:var(--txt);border-radius:6px;transition:.15s;}
.theme-toggle:hover{background:var(--sur2);}
.theme-switch{position:relative;width:36px;height:20px;background:var(--bor2);border-radius:10px;transition:.2s;flex-shrink:0;}
.theme-switch::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--txt2);transition:.2s;}
[data-theme="light"] .theme-switch{background:var(--acc);}
[data-theme="light"] .theme-switch::after{left:18px;background:#fff;}
/* Light theme overrides for elements with hardcoded dark-only colors */
[data-theme="light"] .logo-box{color:#fff;}
[data-theme="light"] .hbtn.prim{color:#fff;}
[data-theme="light"] .hbtn.prim:hover{background:var(--acc);}
[data-theme="light"] .btn-p{color:#fff;}
[data-theme="light"] .btn-p:hover{color:#fff;}
[data-theme="light"] .uav{color:#fff;}
[data-theme="light"] .mav{color:#fff;}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:var(--bor);}
[data-theme="light"] .ab-blocked{background:#fef3c7;color:#92400e;}
[data-theme="light"] .mo{background:rgba(0,0,0,.35);}
[data-theme="light"] .mbox{box-shadow:0 12px 40px rgba(0,0,0,.12);}
/* ── Infection Control ── */
#ic-tabs .fchip.on{background:rgba(0,201,167,.15);font-weight:600;}
.ic-risk-low{background:var(--ok);color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;}
.ic-risk-medium{background:var(--warn);color:#000;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;}
.ic-risk-high{background:#f97316;color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;}
.ic-risk-critical{background:var(--dan);color:#fff;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;}
.ic-compliance-bar{height:6px;border-radius:3px;background:var(--sur2);overflow:hidden;margin:4px 0;}
.ic-compliance-fill{height:100%;border-radius:3px;transition:width .3s;}
