*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#0a0a0a;--black2:#111111;--black3:#1a1a1a;--black4:#242424;--black5:#2e2e2e;
  --yellow:#FFD700;--yellow-pale:#2a2200;
  --white:#fff;--gray2:#e0e0e0;--gray3:#9a9a9a;--gray4:#555;
  --green:#22c55e;--green-bg:rgba(34,197,94,.1);
  --red:#ef4444;--red-bg:rgba(239,68,68,.1);
  --blue:#3b82f6;--blue-bg:rgba(59,130,246,.1);
  --sidebar:250px;--header:64px;--r:6px;--rlg:10px;
}
body{font-family:'Barlow',sans-serif;background:var(--black);color:var(--white);min-height:100vh;font-size:14px}

/* LOGIN */
#login-screen{position:fixed;inset:0;background:var(--black);display:flex;align-items:center;justify-content:center;z-index:999}
.lw{width:380px}
.lw img{height:42px;width:auto;margin-bottom:1.75rem;display:block;margin-left:auto;margin-right:auto}
.l-bar{height:3px;background:var(--yellow);border-radius:2px;margin-bottom:1.75rem}
.l-h{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:800;letter-spacing:.04em;margin-bottom:4px}
.l-s{font-size:13px;color:var(--gray3);margin-bottom:1.75rem}
.l-f{margin-bottom:.9rem}
.l-f label{display:block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray3);margin-bottom:5px}
.l-f input{width:100%;padding:10px 14px;background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);font-size:14px;font-family:inherit;color:var(--white);outline:none}
.l-f input:focus{border-color:var(--yellow)}
.l-pw-wrap{position:relative;display:flex;align-items:center}
.l-pw-wrap input{width:100%;padding-right:40px}
.l-eye-btn{position:absolute;right:10px;background:none;border:none;color:var(--gray4);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .15s}
.l-eye-btn:hover{color:var(--white)}
.l-btn{width:100%;padding:11px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-size:13px;font-weight:800;font-family:inherit;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;margin-top:.4rem}
.l-btn:hover{background:#ffe033}
.l-err{color:#ff5252;font-size:12px;margin-top:8px;display:none;background:rgba(255,82,82,.08);border:1px solid rgba(255,82,82,.2);border-radius:var(--r);padding:7px 12px}

/* APP */
#app{display:none}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar);background:var(--black2);border-right:1px solid var(--black4);display:flex;flex-direction:column;z-index:100}
.sb-brand{height:var(--header);display:flex;align-items:center;padding:0 1.25rem;border-bottom:1px solid var(--black4);flex-shrink:0}
.sb-brand img{height:27px;width:auto}
.nav{padding:.9rem .75rem;flex:1;overflow-y:auto}
.nav::-webkit-scrollbar{width:3px}
.nav::-webkit-scrollbar-thumb{background:var(--black5)}
.nav-sec{font-size:10px;font-weight:700;color:var(--gray4);letter-spacing:.12em;text-transform:uppercase;padding:0 .5rem;margin:1.1rem 0 .3rem}
.nav-sec:first-child{margin-top:0}
.ni-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--r);color:var(--gray3);font-size:13px;font-weight:500;cursor:pointer;user-select:none}
.ni-item:hover{background:var(--black3);color:var(--white)}
.ni-item.active{background:var(--yellow-pale);color:var(--yellow);font-weight:600}
.ni-item .ico{width:15px;height:15px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.chev{margin-left:auto;width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .2s;flex-shrink:0}
.ni-item.expanded .chev{transform:rotate(180deg)}
.nav-sub{overflow:hidden;max-height:0;transition:max-height .25s ease}
.nav-sub.open{max-height:300px}
.ns-item{display:flex;align-items:center;gap:7px;padding:6px 10px 6px 30px;border-radius:var(--r);color:var(--gray4);font-size:12.5px;font-weight:500;cursor:pointer;user-select:none}
.ns-item:hover{background:var(--black3);color:var(--white)}
.ns-item.active{color:var(--yellow);font-weight:600}
.ns-item::before{content:"";width:4px;height:4px;border-radius:50%;background:currentColor;flex-shrink:0}
.nss-item{display:flex;align-items:center;gap:7px;padding:5px 10px 5px 46px;border-radius:var(--r);color:var(--gray4);font-size:12px;font-weight:500;cursor:pointer;user-select:none}
.nss-item:hover{background:var(--black3);color:var(--white)}
.nss-item.active{color:var(--yellow);font-weight:600}
.nss-item::before{content:"";width:3px;height:3px;border-radius:50%;background:currentColor;flex-shrink:0}
.sb-foot{padding:.75rem;border-top:1px solid var(--black4);flex-shrink:0}
.u-row{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r);cursor:pointer}
.u-row:hover{background:var(--black3)}
.av{width:29px;height:29px;border-radius:50%;background:var(--yellow);color:var(--black);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.u-nm{font-size:13px;font-weight:600}
.u-rl{font-size:11px;color:var(--gray4)}

.hdr{position:fixed;top:0;left:var(--sidebar);right:0;height:var(--header);background:var(--black2);border-bottom:1px solid var(--black4);display:flex;align-items:center;justify-content:space-between;padding:0 1.75rem;z-index:50}
.hdr-t{font-family:'Barlow Condensed',sans-serif;font-size:19px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.hdr-t span{color:var(--yellow)}
.srch{display:flex;align-items:center;gap:7px;padding:7px 13px;background:var(--black3);border:1px solid var(--black4);border-radius:var(--r)}
.srch:focus-within{border-color:var(--yellow)}
.srch svg{width:13px;height:13px;stroke:var(--gray4);fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.srch input{background:transparent;border:none;outline:none;font-family:inherit;font-size:13px;color:var(--white);width:170px}
.srch input::placeholder{color:var(--gray4)}

.main{margin-left:var(--sidebar);margin-top:var(--header);padding:1.75rem;min-height:calc(100vh - var(--header))}
.page{display:none}
.page.active{display:block}.page.active.pg-stretch{display:flex;flex-direction:column;min-height:calc(100vh - var(--header) - 3.5rem)}
.pg-hdr{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.5rem;border-bottom:1px solid var(--black4);padding-bottom:1.1rem}
.pg-h{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.pg-h span{color:var(--yellow)}
.pg-s{font-size:13px;color:var(--gray3);margin-top:3px}
.btn-p{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}
.btn-p:hover{background:#ffe033}
.btn-p svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* MTD LAYOUT: side-by-side calendar + KPIs */
.mtd-top{display:grid;grid-template-columns:240px 1fr;gap:1.25rem;margin-bottom:1.25rem;align-items:start}

/* MINI CALENDAR */
.mini-cal{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem}
.mc-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.mc-mo{font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--yellow)}
.mc-asof{font-size:9px;color:var(--gray4);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.mc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.mc-dow{text-align:center;font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--gray4);padding-bottom:3px}
.mc-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:4px;font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;cursor:pointer;border:1px solid transparent;transition:all .1s;position:relative}
.mc-cell.work{background:var(--black4);color:var(--gray2)}
.mc-cell.work:hover{border-color:var(--yellow);color:var(--yellow)}
.mc-cell.sel{background:var(--yellow);color:var(--black);border-color:var(--yellow)}
.mc-cell.today{background:var(--black4);color:var(--gray4);cursor:not-allowed}
.mc-cell.today::after{content:'•';position:absolute;bottom:0;font-size:8px;color:var(--gray4);line-height:1}
.mc-cell.wknd,.mc-cell.empty,.mc-cell.future{background:transparent;color:var(--gray4);cursor:default;opacity:.25;border-color:transparent}
.mc-legend{margin-top:.75rem;display:flex;flex-direction:column;gap:4px}
.mc-leg-row{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--gray4)}
.mc-leg-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}

/* KPI GRID right side */
.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.kc{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:.9rem 1rem;position:relative;overflow:hidden}
.kc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--yellow)}
.kc-lbl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);margin-bottom:5px}
.kc-val{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;line-height:1;margin-bottom:4px}
.kc-cmp{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.kc-apr{font-size:11px;color:var(--gray4)}
.kc-apr b{color:var(--gray3)}
.d-up{color:var(--green);font-size:10px;font-weight:700}
.d-dn{color:var(--red);font-size:10px;font-weight:700}
.d-nt{color:var(--gray4);font-size:10px}

/* SPLIT W2/1099 */
.split-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}
.scard{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem}
.scard-t{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);margin-bottom:.75rem;padding-bottom:6px;border-bottom:1px solid var(--black4)}
.scard-kpis{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.sk{background:var(--black4);border-radius:var(--r);padding:8px 10px}
.sk-l{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);margin-bottom:3px}
.sk-v{font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;line-height:1}

/* BUDGET */
.bcard{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:1.25rem}
.bcard-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.bcard-t{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.pbadge{font-size:9px;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.04em;text-transform:uppercase}
.pbadge.ahead{background:var(--green-bg);color:var(--green)}
.pbadge.behind{background:var(--red-bg);color:var(--red)}
.brow{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.brow:last-child{margin-bottom:0}
.bl{font-size:10px;font-weight:600;color:var(--gray4);width:90px;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}
.bt{flex:1;height:7px;background:var(--black4);border-radius:4px;overflow:hidden}
.bf{height:100%;border-radius:4px;min-width:1px;transition:width .5s ease}
.bp{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;width:44px;text-align:right;flex-shrink:0}
.bv{font-size:10px;color:var(--gray4);flex-shrink:0;text-align:right;min-width:140px}

/* REP TABLE */
.rep-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.rt-hdr{display:grid;grid-template-columns:160px 56px 65px 105px 105px 65px 55px 1fr;padding:9px 14px;border-bottom:1px solid var(--black4);background:var(--black4);gap:6px}
.rt-hdr span{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4)}
.rt-row{display:grid;grid-template-columns:160px 56px 65px 105px 105px 65px 55px 1fr;padding:10px 14px;border-bottom:1px solid var(--black4);gap:6px;align-items:center}
.rt-row:last-child{border-bottom:none}
.rt-row:hover{background:var(--black4)}
.rc{display:flex;align-items:center;gap:7px;min-width:0}
.ri{width:26px;height:26px;border-radius:5px;background:var(--yellow-pale);border:1px solid rgba(255,215,0,.2);display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;color:var(--yellow);flex-shrink:0;letter-spacing:.01em}
.rn{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rm{font-size:9px;margin-top:1px}
.pill{font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 6px;border-radius:20px}
.pw2{background:var(--blue-bg);color:var(--blue)}
.p99{background:rgba(255,215,0,.1);color:var(--yellow)}
.pof{background:var(--red-bg);color:var(--red)}
.rnum{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700}
.rsm{font-size:11px;color:var(--gray3)}
.gbg{width:100%;height:4px;background:var(--black5);border-radius:2px;margin-bottom:2px}
.gfill{height:100%;border-radius:2px;min-width:1px}
.glbl{font-size:9px;color:var(--gray4)}

/* DASHBOARD */
.wb{background:var(--black3);border:1px solid var(--black4);border-left:4px solid var(--yellow);border-radius:var(--rlg);padding:1.25rem 1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between}
.wb-t h2{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:3px}
.wb-t h2 span{color:var(--yellow)}
.wb-t p{font-size:12px;color:var(--gray3)}
.wb-badge{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--yellow);color:var(--black);padding:4px 11px;border-radius:20px}
.mg{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin-bottom:1.5rem}
.mc{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.25rem;cursor:pointer;position:relative;overflow:hidden}
.mc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--yellow);opacity:0;transition:opacity .15s}
.mc:hover{border-color:var(--gray4);background:var(--black4)}
.mc:hover::before{opacity:1}
.mc.soon{opacity:.4;cursor:default;pointer-events:none}
.mci{width:36px;height:36px;border-radius:var(--r);background:var(--yellow-pale);display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}
.mci svg{width:18px;height:18px;stroke:var(--yellow);fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.mct{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;margin-bottom:3px}
.mcd{font-size:11px;color:var(--gray3);line-height:1.4}
.mt{display:inline-block;margin-top:8px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:20px}
.mt.on{background:rgba(255,215,0,.12);color:var(--yellow)}
.mt.off{background:var(--black4);color:var(--gray4)}
.db{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.dbc{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.1rem 1.3rem}
.dbc-t{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1rem}
.ai{display:flex;align-items:flex-start;gap:9px;padding:8px 0;border-bottom:1px solid var(--black4)}
.ai:last-child{border-bottom:none}
.ad{width:5px;height:5px;border-radius:50%;background:var(--yellow);flex-shrink:0;margin-top:5px}
.at{font-size:12px;color:var(--gray2);flex:1;line-height:1.4}
.at strong{color:var(--white);font-weight:600}
.atm{font-size:10px;color:var(--gray4);flex-shrink:0;padding-top:2px}
.sg{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.sb{background:var(--black4);border-radius:var(--r);padding:10px;text-align:center}
.sbn{font-family:'Barlow Condensed',sans-serif;font-size:24px;font-weight:800;color:var(--yellow);line-height:1;margin-bottom:3px}
.sbl{font-size:10px;color:var(--gray3);text-transform:uppercase;letter-spacing:.05em}

/* UPLOAD/FILES */
.uz{border:2px dashed var(--black5);border-radius:var(--rlg);padding:1.75rem;text-align:center;cursor:pointer;background:var(--black3);margin-bottom:1.25rem}
.uz:hover,.uz.drag{border-color:var(--yellow);background:var(--yellow-pale)}
.uz svg{width:28px;height:28px;stroke:var(--gray4);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;margin-bottom:8px}
.uz-t{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;color:var(--gray3);margin-bottom:3px}
.uz-s{font-size:12px;color:var(--gray4)}
.uz-s span{color:var(--yellow);font-weight:600}
.ftw{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.fth{display:grid;grid-template-columns:1fr 90px 130px 80px;padding:9px 14px;border-bottom:1px solid var(--black4);background:var(--black4)}
.fth span{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.fr{display:grid;grid-template-columns:1fr 90px 130px 80px;padding:11px 14px;border-bottom:1px solid var(--black4);align-items:center}
.fr:last-child{border-bottom:none}
.fr:hover{background:var(--black4)}
.fnc{display:flex;align-items:center;gap:9px;min-width:0}
.fi{width:30px;height:30px;border-radius:5px;background:var(--black5);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fi.pdf{background:rgba(255,82,82,.12)} .fi.pdf svg{stroke:#ff5252}
.fi.doc{background:rgba(66,133,244,.12)} .fi.doc svg{stroke:#4285f4}
.fi.xls{background:rgba(34,197,94,.12)} .fi.xls svg{stroke:#22c55e}
.fi.ppt{background:rgba(255,167,38,.12)} .fi.ppt svg{stroke:#ffa726}
.fi svg{width:14px;height:14px;fill:none;stroke:var(--gray3);stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}
.fn{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fsz,.fdt{font-size:11px;color:var(--gray3)}
.fa{display:flex;gap:5px;justify-content:flex-end}
.ib{width:28px;height:28px;border-radius:var(--r);border:1px solid var(--black5);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray3)}
.ib:hover{border-color:var(--yellow);color:var(--yellow);background:var(--yellow-pale)}
.ib.del:hover{border-color:#ff5252;color:#ff5252;background:rgba(255,82,82,.08)}
.ib svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.et{padding:2rem;text-align:center;color:var(--gray4);font-size:12px}
.et svg{width:24px;height:24px;stroke:var(--black5);fill:none;stroke-width:1.5;margin-bottom:6px;display:block;margin-left:auto;margin-right:auto}
.ph{background:var(--black3);border:1px dashed var(--black4);border-radius:var(--rlg);padding:2.5rem;text-align:center;color:var(--gray4);margin-bottom:.9rem}
.ph svg{width:36px;height:36px;stroke:var(--black5);fill:none;stroke-width:1.5;margin:0 auto .75rem;display:block}
.ph strong{display:block;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray4);margin-bottom:5px}
.ph p{font-size:12px}
.stabs{display:flex;gap:4px;margin-bottom:1.25rem;background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:3px}
.stab{flex:1;padding:7px 10px;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:center;cursor:pointer;color:var(--gray3);border:none;background:transparent}
.stab:hover{color:var(--white)}
.stab.active{background:var(--yellow);color:var(--black)}
input[type=file]{display:none}

.ql-item{text-decoration:none;color:var(--gray3) !important;}
.ql-item:hover{background:var(--black3);color:var(--yellow) !important;}
.ql-item.active{background:transparent !important;color:var(--gray3) !important;font-weight:500 !important;}

.acc-section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.acc-section-title{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;}
.acc-totals-row{display:grid;gap:.75rem;margin-bottom:1.25rem;}
.acc-totals-row.five{grid-template-columns:repeat(5,1fr);}
.acc-totals-row.four{grid-template-columns:repeat(4,1fr);}
.acc-kc{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:.9rem 1rem;position:relative;overflow:hidden;}
.acc-kc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--yellow);}
.acc-kc.red::after{background:var(--red);}
.acc-kc.green::after{background:var(--green);}
.acc-kc.blue::after{background:var(--blue);}
.acc-kc.orange::after{background:#f97316;}
.acc-kl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);margin-bottom:5px;}
.acc-kv{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;line-height:1;}
.acc-ks{font-size:10px;color:var(--gray4);margin-top:3px;}

/* Aging bar */
.aging-bar-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:1.25rem;}
.aging-bar-title{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);margin-bottom:.9rem;}
.aging-segments{display:flex;height:12px;border-radius:6px;overflow:hidden;gap:2px;margin-bottom:.6rem;}
.ag-seg{height:100%;border-radius:3px;min-width:2px;transition:width .5s;}
.aging-legend{display:flex;gap:16px;flex-wrap:wrap;}
.ag-leg{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--gray3);}
.ag-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0;}

/* Detail table */
.det-search-wrap{display:flex;align-items:center;gap:8px;margin-bottom:.75rem;}
.det-search{flex:1;display:flex;align-items:center;gap:7px;padding:7px 12px;background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);}
.det-search:focus-within{border-color:var(--yellow);}
.det-search svg{width:13px;height:13px;stroke:var(--gray4);fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;}
.det-search input{background:transparent;border:none;outline:none;font-family:inherit;font-size:12px;color:var(--white);width:100%;}
.det-search input::placeholder{color:var(--gray4);}
.det-count{font-size:11px;color:var(--gray4);white-space:nowrap;}
.det-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden;}
.det-table{width:100%;border-collapse:collapse;}
.det-table th{padding:9px 12px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);background:var(--black4);text-align:left;white-space:nowrap;cursor:pointer;user-select:none;}
.det-table th:hover{color:var(--white);}
.det-table th.sort-asc::after{content:' ▲';font-size:8px;}
.det-table th.sort-desc::after{content:' ▼';font-size:8px;}
.det-table td{padding:9px 12px;font-size:12px;color:var(--gray2);border-bottom:1px solid var(--black4);white-space:nowrap;}
.det-table tr:last-child td{border-bottom:none;}
.det-table tr:hover td{background:var(--black4);}
.det-table td.num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:600;}
.det-table td.pos{color:var(--green);}
.det-table td.warn{color:var(--yellow);}
.det-table td.danger{color:var(--red);}
.ag-pill{display:inline-block;padding:1px 6px;border-radius:10px;font-size:9px;font-weight:700;}

/* Overview grid */
.ov-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem;}
.ov-card{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.25rem 1.5rem;}
.ov-card-t{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem;padding-bottom:8px;border-bottom:1px solid var(--black4);display:flex;align-items:center;justify-content:space-between;}
.ov-card-t span{color:var(--yellow);}
.ov-total{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:800;color:var(--yellow);margin-bottom:4px;line-height:1;}
.ov-sub{font-size:11px;color:var(--gray4);margin-bottom:1rem;}
.ov-aging{display:flex;flex-direction:column;gap:6px;}
.ov-aging-row{display:flex;align-items:center;gap:8px;}
.ov-aging-lbl{font-size:10px;color:var(--gray4);width:80px;flex-shrink:0;}
.ov-aging-bar{flex:1;height:5px;background:var(--black4);border-radius:3px;overflow:hidden;}
.ov-aging-fill{height:100%;border-radius:3px;}
.ov-aging-val{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;width:90px;text-align:right;flex-shrink:0;}
.bbc-ph{background:var(--black4);border-radius:var(--r);padding:2rem;text-align:center;color:var(--gray4);font-size:12px;margin-top:.75rem;}

/* MARKETING MATERIALS */
.mkt-section-label{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--gray4);padding:0 4px;margin:1.5rem 0 .6rem;}
.mkt-section-label:first-child{margin-top:0;}
.mkt-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem;}
.mkt-list-row{display:flex;align-items:center;gap:1rem;background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);padding:.85rem 1.1rem;transition:border-color .12s;}
.mkt-list-row:hover{border-color:var(--yellow);}
.mkt-list-info{flex:1;min-width:0;}
.mkt-list-name{font-size:13px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mkt-list-meta{font-size:11px;color:var(--gray4);margin-top:2px;}
.mkt-dl-btn{height:34px;display:flex;align-items:center;justify-content:center;padding:0 10px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);cursor:pointer;flex-shrink:0;transition:background .12s;}
.mkt-dl-btn:hover{background:#ffe033;}
.mkt-dl-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}
.mkt-empty{background:var(--black3);border:1px dashed var(--black4);border-radius:var(--rlg);padding:3rem;text-align:center;color:var(--gray4);}
.mkt-empty svg{width:36px;height:36px;stroke:var(--black5);fill:none;stroke-width:1.5;margin:0 auto .75rem;display:block;}
.mkt-empty strong{display:block;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray4);margin-bottom:5px;}
.mkt-empty p{font-size:12px;}
/* ── Carriers Page ── */
.nfc-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-bottom:1.25rem}
.nfc-kc{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:.9rem 1rem;position:relative;overflow:hidden}
.nfc-kc::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--yellow)}
.nfc-kc-l{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);margin-bottom:5px}
.nfc-kc-v{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;line-height:1;margin-bottom:3px}
.nfc-kc-s{font-size:11px;color:var(--gray4)}
.nfc-kc.green .nfc-kc-v{color:var(--green)}
.nfc-kc.yellow .nfc-kc-v{color:var(--yellow)}
.nfc-kc.red .nfc-kc-v{color:var(--red)}
.nfc-kc.blue .nfc-kc-v{color:var(--blue)}

.nfc-filters{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:1.25rem;display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.nfc-fg{display:flex;flex-direction:column;gap:4px;min-width:140px;flex:1}
.nfc-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.nfc-fg input,.nfc-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.nfc-fg input:focus,.nfc-fg select:focus{border-color:var(--yellow)}
.nfc-fg input::placeholder{color:var(--gray4)}
.nfc-fg select option{background:var(--black3)}
.nfc-btn{padding:8px 18px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;align-self:flex-end;white-space:nowrap;flex-shrink:0}
.nfc-btn:hover{background:#ffe033}
.nfc-btn.sec{background:var(--black5);color:var(--gray2)}
.nfc-btn.sec:hover{background:var(--black4);color:var(--white)}

.nfc-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden;display:flex;flex-direction:column;flex:1}
.nfc-tw-inner{flex:1;height:calc(100vh - var(--header) - 280px);min-height:300px;overflow-y:auto}
.nfc-tw-inner::-webkit-scrollbar{width:4px}
.nfc-tw-inner::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.nfc-table{width:100%;border-collapse:collapse}
.nfc-table th{position:sticky;top:0;background:var(--black4);padding:9px 12px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap;z-index:2}
.nfc-table td{padding:10px 12px;border-bottom:1px solid var(--black4);font-size:12px;color:var(--gray2);vertical-align:middle}
.nfc-table tr:last-child td{border-bottom:none}
.nfc-table tr:hover td{background:var(--black4)}
.nfc-table .strong{color:var(--white);font-weight:600}
.nfc-table .muted{font-size:10px;color:var(--gray4);margin-top:2px}
.nfc-table .num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--white)}
.nfc-tw-footer{padding:9px 14px;border-top:1px solid var(--black4);font-size:11px;color:var(--gray4)}

.nfc-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.nfc-pill.low{background:var(--green-bg);color:var(--green)}
.nfc-pill.medium{background:rgba(251,191,36,.1);color:#fbbf24}
.nfc-pill.high{background:var(--red-bg);color:var(--red)}
.nfc-pill.ranked{background:var(--green-bg);color:var(--green)}
.nfc-pill.fresh{background:var(--blue-bg);color:var(--blue)}
.nfc-pill.exact{background:rgba(255,215,0,.12);color:var(--yellow)}
.nfc-pill.related{background:var(--blue-bg);color:var(--blue)}

.nfc-rank{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:5px;background:var(--black5);font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;color:var(--gray3)}
.nfc-rank.top{background:rgba(255,215,0,.15);color:var(--yellow)}
.nfc-empty{padding:2rem;text-align:center;color:var(--gray4);font-size:12px}
.nfc-empty svg{width:28px;height:28px;stroke:var(--black5);fill:none;stroke-width:1.5;display:block;margin:0 auto .5rem}

.nfc-contact{font-size:11px;color:var(--gray3);line-height:1.5}
.nfc-contact a{color:var(--blue);text-decoration:none}
.nfc-contact a:hover{text-decoration:underline}

.nfc-export-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}
.nfc-export-row span{font-size:12px;color:var(--gray4)}


/* ── All Unpaid Dashboard ── */
.up-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-bottom:1.25rem}
.up-filters{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:1.25rem;display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.up-fg{display:flex;flex-direction:column;gap:4px;min-width:130px;flex:1}
.up-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.up-fg input,.up-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.up-fg input:focus,.up-fg select:focus{border-color:var(--yellow)}
.up-fg input::placeholder{color:var(--gray4)}
.up-fg select option{background:var(--black3)}
.up-btn{padding:8px 16px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;align-self:flex-end;white-space:nowrap;flex-shrink:0}
.up-btn:hover{background:#ffe033}
.up-btn.sec{background:var(--black5);color:var(--gray2)}
.up-btn.sec:hover{background:var(--black4);color:var(--white)}
.up-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.up-tw-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--black4);gap:.5rem;flex-wrap:wrap}
.up-tw-bar span{font-size:11px;color:var(--gray4)}
.up-tw-inner{max-height:560px;overflow-y:auto}
.up-tw-inner::-webkit-scrollbar{width:4px}
.up-tw-inner::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.up-table{width:100%;border-collapse:collapse;font-size:12px}
.up-table th{position:sticky;top:0;background:var(--black4);padding:8px 10px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap;z-index:2;cursor:pointer;user-select:none}
.up-table th:hover{color:var(--white)}
.up-table th .sort-ico{margin-left:4px;opacity:.4;font-style:normal}
.up-table th.asc .sort-ico::after{content:'↑';opacity:1}
.up-table th.desc .sort-ico::after{content:'↓';opacity:1}
.up-table th:not(.asc):not(.desc) .sort-ico::after{content:'↕'}
.up-table td{padding:8px 10px;border-bottom:1px solid var(--black4);color:var(--gray2);vertical-align:middle;white-space:nowrap}
.up-table tr:last-child td{border-bottom:none}
.up-table tr:hover td{background:rgba(255,255,255,.03)}
.up-table .num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--white)}
.up-table .muted{font-size:10px;color:var(--gray4);margin-top:1px}
.up-bucket{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.up-bucket.b31{background:rgba(251,191,36,.1);color:#fbbf24}
.up-bucket.b46{background:rgba(251,146,60,.1);color:#fb923c}
.up-bucket.b61{background:rgba(239,68,68,.1);color:#ef4444}
.up-bucket.b90{background:var(--red-bg);color:var(--red)}
.up-paid{color:var(--green);font-size:10px;font-weight:700}
.up-unpaid{color:var(--red);font-size:10px;font-weight:700}
.up-type-ach{background:var(--blue-bg);color:var(--blue);display:inline-flex;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.up-type-chk{background:var(--black5);color:var(--gray3);display:inline-flex;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}


/* ── All Unpaid Dashboard ── */
.up-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-bottom:1.25rem}
.up-filters{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:1.25rem;display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.up-fg{display:flex;flex-direction:column;gap:4px;min-width:130px;flex:1}
.up-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.up-fg input,.up-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.up-fg input:focus,.up-fg select:focus{border-color:var(--yellow)}
.up-fg input::placeholder{color:var(--gray4)}
.up-fg select option{background:var(--black3)}
.up-btn{padding:8px 16px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;align-self:flex-end;white-space:nowrap;flex-shrink:0}
.up-btn:hover{background:#ffe033}
.up-btn.sec{background:var(--black5);color:var(--gray2)}
.up-btn.sec:hover{background:var(--black4);color:var(--white)}
.up-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.up-tw-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--black4);gap:.5rem;flex-wrap:wrap}
.up-tw-bar span{font-size:11px;color:var(--gray4)}
.up-tw-inner{max-height:560px;overflow-y:auto}
.up-tw-inner::-webkit-scrollbar{width:4px}
.up-tw-inner::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.up-table{width:100%;border-collapse:collapse;font-size:12px}
.up-table th{position:sticky;top:0;background:var(--black4);padding:8px 10px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap;z-index:2;cursor:pointer;user-select:none}
.up-table th:hover{color:var(--white)}
.up-table th .sort-ico{margin-left:4px;opacity:.4;font-style:normal}
.up-table th.asc .sort-ico::after{content:'↑';opacity:1}
.up-table th.desc .sort-ico::after{content:'↓';opacity:1}
.up-table th:not(.asc):not(.desc) .sort-ico::after{content:'↕'}
.up-table td{padding:6px 10px;border-bottom:1px solid var(--black4);color:var(--gray2);vertical-align:middle;white-space:nowrap}
.up-table tr:last-child td{border-bottom:none}
.up-table tr:hover td{background:rgba(255,255,255,.02)}
.up-table .num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--white)}
.up-bucket{display:inline-flex;align-items:center;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.up-bucket.b31{background:rgba(251,191,36,.1);color:#fbbf24}
.up-bucket.b46{background:rgba(251,146,60,.1);color:#fb923c}
.up-bucket.b61{background:rgba(239,68,68,.1);color:#ef4444}
.up-bucket.b90{background:var(--red-bg);color:var(--red)}
.up-editable{outline:none;border-radius:3px;padding:2px 5px;display:inline-block;cursor:text;min-width:30px}
.up-editable:hover{background:var(--black4)}
.up-editable:focus{background:var(--black4);box-shadow:0 0 0 1px var(--yellow);color:var(--white)}
.up-edited{box-shadow:0 0 0 1px rgba(255,215,0,.5) !important;background:rgba(255,215,0,.07) !important;border-radius:3px}
.up-save-btn{display:none;padding:2px 9px;background:var(--green);color:#000;border:none;border-radius:3px;font-size:9px;font-weight:800;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}
tr.row-dirty .up-save-btn{display:inline-flex}


.up-date-input{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:3px 6px;font-family:inherit;font-size:11px;outline:none;cursor:pointer;min-width:120px;color-scheme:dark}
.up-date-input:focus{border-color:var(--yellow);box-shadow:0 0 0 1px var(--yellow)}
.up-date-input:hover{border-color:var(--gray4)}


/* ── Quickpay Dashboard ── */
.qp-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem}
.qp-filters{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:1.25rem;display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.qp-fg{display:flex;flex-direction:column;gap:4px;min-width:130px;flex:1}
.qp-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.qp-fg input,.qp-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.qp-fg input:focus,.qp-fg select:focus{border-color:var(--yellow)}
.qp-fg input::placeholder{color:var(--gray4)}
.qp-fg select option{background:var(--black3)}
.qp-btn{padding:8px 16px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;align-self:flex-end;white-space:nowrap;flex-shrink:0}
.qp-btn:hover{background:#ffe033}
.qp-btn.sec{background:var(--black5);color:var(--gray2)}
.qp-btn.sec:hover{background:var(--black4);color:var(--white)}
.qp-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.qp-tw-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--black4);gap:.5rem;flex-wrap:wrap}
.qp-tw-bar span{font-size:11px;color:var(--gray4)}
.qp-tw-inner{max-height:560px;overflow-y:auto}
.qp-tw-inner::-webkit-scrollbar{width:4px}
.qp-tw-inner::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.qp-table{width:100%;border-collapse:collapse;font-size:12px}
.qp-table th{position:sticky;top:0;background:var(--black4);padding:8px 10px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap;z-index:2;cursor:pointer;user-select:none}
.qp-table th:hover{color:var(--white)}
.qp-table th .si::after{content:'↕';margin-left:4px;opacity:.35}
.qp-table th.asc .si::after{content:'↑';opacity:1}
.qp-table th.desc .si::after{content:'↓';opacity:1}
.qp-table td{padding:8px 10px;border-bottom:1px solid var(--black4);color:var(--gray2);vertical-align:middle;white-space:nowrap}
.qp-table tr:last-child td{border-bottom:none}
.qp-table tr:hover td{background:rgba(255,255,255,.02)}
.qp-num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--white)}
.qp-check{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;font-size:10px}
.qp-check.yes{background:var(--green-bg);color:var(--green)}
.qp-check.no{background:var(--black5);color:var(--gray4)}
.qp-assigned{display:inline-flex;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.qp-assigned.liezl{background:rgba(139,92,246,.15);color:#a78bfa}
.qp-assigned.jam{background:rgba(59,130,246,.15);color:var(--blue)}
.qp-assigned.renee{background:rgba(236,72,153,.15);color:#f472b6}
.qp-status-done{background:var(--green-bg);color:var(--green);display:inline-flex;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.qp-status-nq{background:rgba(251,191,36,.1);color:#fbbf24;display:inline-flex;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}


.qp-chk-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;border:none;cursor:pointer;font-size:12px;font-weight:700;transition:background .15s,color .15s}
.qp-chk-btn.on{background:var(--green-bg);color:var(--green)}
.qp-chk-btn.on:hover{background:rgba(34,197,94,.25)}
.qp-chk-btn.off{background:var(--black5);color:var(--gray4)}
.qp-chk-btn.off:hover{background:var(--black4);color:var(--white)}
.qp-inline-sel{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:4px 6px;font-family:inherit;font-size:11px;font-weight:700;color:var(--white);outline:none;cursor:pointer;max-width:90px}
.qp-inline-sel:focus{border-color:var(--yellow)}
.qp-notes-ta{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:5px 8px;font-family:inherit;font-size:11px;color:var(--gray2);outline:none;resize:vertical;min-width:220px;max-width:360px;line-height:1.5;width:100%}
.qp-notes-ta:focus{border-color:var(--yellow);color:var(--white)}
.qp-notes-ta::placeholder{color:var(--gray4)}


.qp-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:9999;display:flex;align-items:center;justify-content:center}
#qp-add-modal input,#qp-add-modal select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
#qp-add-modal input:focus,#qp-add-modal select:focus{border-color:var(--yellow)}
#qp-add-modal select option{background:var(--black3)}
#qp-bulk-bar{display:none}


/* ── Commcheck Dashboard ── */
.cc-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;margin-bottom:1.25rem}
.cc-filters{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:1.25rem;display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.cc-fg{display:flex;flex-direction:column;gap:4px;min-width:120px;flex:1}
.cc-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.cc-fg input,.cc-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.cc-fg input:focus,.cc-fg select:focus{border-color:var(--yellow)}
.cc-fg input::placeholder{color:var(--gray4)}
.cc-fg select option{background:var(--black3)}
.cc-btn{padding:8px 16px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;align-self:flex-end;white-space:nowrap;flex-shrink:0}
.cc-btn:hover{background:#ffe033}
.cc-btn.sec{background:var(--black5);color:var(--gray2)}
.cc-btn.sec:hover{background:var(--black4);color:var(--white)}
.cc-btn.danger{background:var(--red-bg);color:var(--red)}
.cc-btn.danger:hover{background:rgba(239,68,68,.2)}
.cc-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.cc-tw-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--black4);gap:.75rem;flex-wrap:wrap}
.cc-tw-bar span{font-size:11px;color:var(--gray4)}
.cc-tw-inner{max-height:580px;overflow-y:auto}
.cc-tw-inner::-webkit-scrollbar{width:4px}
.cc-tw-inner::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.cc-table{width:100%;border-collapse:collapse;font-size:12px}
.cc-table th{position:sticky;top:0;background:var(--black4);padding:8px 10px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap;z-index:2;cursor:pointer;user-select:none}
.cc-table th:hover{color:var(--white)}
.cc-table th .si::after{content:'↕';margin-left:4px;opacity:.35}
.cc-table th.asc .si::after{content:'↑';opacity:1}
.cc-table th.desc .si::after{content:'↓';opacity:1}
.cc-table td{padding:7px 10px;border-bottom:1px solid var(--black4);color:var(--gray2);vertical-align:middle;white-space:nowrap}
.cc-table tr:last-child td{border-bottom:none}
.cc-table tr:hover td{background:rgba(255,255,255,.02)}
.cc-num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--white)}
.cc-pl{display:inline-flex;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.cc-pl-p{background:var(--green-bg);color:var(--green)}
.cc-pl-l{background:var(--red-bg);color:var(--red)}
.cc-trash{background:none;border:none;cursor:pointer;color:var(--gray4);padding:3px 5px;border-radius:3px;font-size:13px;line-height:1}
.cc-trash:hover{color:var(--red);background:var(--red-bg)}
.cc-upload-zone{background:var(--black3);border:2px dashed var(--black5);border-radius:var(--rlg);padding:1.5rem;text-align:center;cursor:pointer;transition:border-color .2s}
.cc-upload-zone:hover{border-color:var(--yellow)}
.cc-upload-zone.drag{border-color:var(--yellow);background:rgba(255,215,0,.04)}


/* ── Weekly KPI Bar ── */
.wk-bar{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:.85rem 1.25rem;margin-bottom:1rem;display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}
.wk-bar-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap}
.wk-sel{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:5px 10px;font-family:inherit;font-size:12px;font-weight:700;color:var(--white);outline:none;cursor:pointer;min-width:130px}
.wk-sel:focus{border-color:var(--yellow)}
.wk-sel option{background:var(--black3)}
.wk-stats{display:flex;gap:1.5rem;flex:1;flex-wrap:wrap}
.wk-stat{display:flex;flex-direction:column;gap:2px}
.wk-stat-l{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4)}
.wk-stat-v{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;line-height:1}
.wk-stat-v.yellow{color:var(--yellow)}
.wk-stat-v.green{color:var(--green)}
.wk-stat-v.blue{color:var(--blue)}
.wk-divider{width:1px;height:36px;background:var(--black5);flex-shrink:0}


/* ── ACH Request Form ── */
.ach-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}
.ach-filters{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:.9rem 1.25rem;margin-bottom:1.1rem;display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.ach-fg{display:flex;flex-direction:column;gap:4px;min-width:120px;flex:1}
.ach-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.ach-fg input,.ach-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.ach-fg input:focus,.ach-fg select:focus{border-color:var(--yellow)}
.ach-fg input::placeholder{color:var(--gray4)}
.ach-fg select option{background:var(--black3)}
.ach-btn{padding:8px 16px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;align-self:flex-end;white-space:nowrap;flex-shrink:0}
.ach-btn:hover{background:#ffe033}
.ach-btn.sec{background:var(--black5);color:var(--gray2)}
.ach-btn.sec:hover{background:var(--black4);color:var(--white)}
.ach-btn.green{background:var(--green);color:#000}
.ach-btn.orange{background:#fb923c;color:#000}
.ach-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.ach-tw-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--black4);gap:.75rem;flex-wrap:wrap}
.ach-tw-bar span{font-size:11px;color:var(--gray4)}
.ach-tw-inner{max-height:560px;overflow-y:auto;overflow-x:auto}
.ach-tw-inner::-webkit-scrollbar{width:4px}
.ach-tw-inner::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.ach-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:12px;table-layout:auto}
.ach-table th{position:sticky;top:0;background:var(--black4);padding:8px 10px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap;z-index:2;cursor:pointer;user-select:none}
.ach-table th:hover{color:var(--white)}
.ach-table th .si::after{content:'↕';margin-left:4px;opacity:.35}
.ach-table th.asc .si::after{content:'↑';opacity:1}
.ach-table th.desc .si::after{content:'↓';opacity:1}
.ach-table td{padding:7px 10px;border-bottom:1px solid var(--black4);color:var(--gray2);vertical-align:middle;white-space:nowrap}
.ach-table tr:last-child td{border-bottom:none}
.ach-table tr:hover td{background:rgba(255,255,255,.02)}
.ach-num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--white)}
.ach-inqp-y{display:inline-flex;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;background:var(--green-bg);color:var(--green)}
.ach-inqp-n{display:inline-flex;padding:2px 7px;border-radius:20px;font-size:9px;font-weight:700;background:var(--black5);color:var(--gray4)}
.ach-tag{display:inline-flex;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;background:rgba(251,191,36,.1);color:#fbbf24;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ach-trash{background:none;border:none;cursor:pointer;color:var(--gray4);padding:3px 5px;border-radius:3px;font-size:13px;line-height:1}
.ach-trash:hover{color:var(--red);background:var(--red-bg)}
.ach-move-btn{background:none;border:1px solid var(--black5);cursor:pointer;color:var(--gray4);padding:2px 7px;border-radius:3px;font-size:9px;font-weight:700;white-space:nowrap}
.ach-move-btn:hover{border-color:var(--yellow);color:var(--yellow)}
/* Add modal */
#ach-add-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:9999;align-items:flex-start;justify-content:center;padding-top:40px;overflow-y:auto}
.ach-modal-box{background:var(--black2);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.75rem;width:640px;max-width:95vw}
.ach-modal-box input,.ach-modal-box select,.ach-modal-box textarea{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.ach-modal-box input:focus,.ach-modal-box select:focus,.ach-modal-box textarea:focus{border-color:var(--yellow)}
.ach-modal-box select option{background:var(--black3)}
.ach-entry-row{background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);padding:.85rem;margin-bottom:.6rem;position:relative}
.ach-entry-remove{position:absolute;top:.6rem;right:.6rem;background:none;border:none;cursor:pointer;color:var(--gray4);font-size:13px;padding:2px 5px;border-radius:3px}
.ach-entry-remove:hover{color:var(--red);background:var(--red-bg)}
.ach-notes-ta{min-height:56px;resize:vertical;line-height:1.5}
/* ACH column widths — min-width per col, table scrolls horizontally */
.ach-table th,.ach-table td{white-space:nowrap}
.ach-table th:nth-child(1),.ach-table td:nth-child(1){min-width:60px}   /* In QP */
.ach-table th:nth-child(2),.ach-table td:nth-child(2){min-width:120px}  /* Request Date */
.ach-table th:nth-child(3),.ach-table td:nth-child(3){min-width:150px}  /* Tagging */
.ach-table th:nth-child(4),.ach-table td:nth-child(4){min-width:90px}   /* PRO # */
.ach-table th:nth-child(5),.ach-table td:nth-child(5){min-width:200px}  /* Payee */
.ach-table th:nth-child(6),.ach-table td:nth-child(6){min-width:110px}  /* Amount */
.ach-table th:nth-child(7),.ach-table td:nth-child(7){min-width:160px}  /* Bank Account */
.ach-table th:nth-child(8),.ach-table td:nth-child(8){min-width:130px}  /* Routing */
.ach-table th:nth-child(9),.ach-table td:nth-child(9){min-width:140px}  /* Bank Name */
.ach-table th:nth-child(10),.ach-table td:nth-child(10){min-width:150px}/* Orig Check # */
.ach-table th:nth-child(11),.ach-table td:nth-child(11){min-width:130px}/* Orig Check Date */
.ach-table th:nth-child(12),.ach-table td:nth-child(12){min-width:120px}/* Orig Amount */
.ach-table th:nth-child(13),.ach-table td:nth-child(13){min-width:220px;white-space:normal} /* Comment */
.ach-table th:nth-child(14),.ach-table td:nth-child(14){min-width:120px} /* Actions */
.ach-table .up-editable{display:inline-block;min-width:60px}


/* ── Check Register ── */
.cr-upload-bar{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:.9rem 1.25rem;margin-bottom:1.1rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.cr-filters{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:.9rem 1.25rem;margin-bottom:1.1rem;display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.cr-fg{display:flex;flex-direction:column;gap:4px;min-width:130px;flex:1}
.cr-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.cr-fg input,.cr-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%}
.cr-fg input:focus,.cr-fg select:focus{border-color:var(--yellow)}
.cr-fg input::placeholder{color:var(--gray4)}
.cr-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden}
.cr-tw-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid var(--black4);gap:.5rem}
.cr-tw-bar span{font-size:11px;color:var(--gray4)}
.cr-tw-inner{max-height:560px;overflow-x:auto;overflow-y:auto}
.cr-tw-inner::-webkit-scrollbar{width:4px;height:4px}
.cr-tw-inner::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.cr-table{width:max-content;min-width:100%;border-collapse:collapse;font-size:12px}
.cr-table th{position:sticky;top:0;background:var(--black4);padding:8px 12px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);white-space:nowrap;z-index:2;cursor:pointer;user-select:none;min-width:100px}
.cr-table th:hover{color:var(--white)}
.cr-table th .si::after{content:'↕';margin-left:4px;opacity:.35}
.cr-table th.asc .si::after{content:'↑';opacity:1}
.cr-table th.desc .si::after{content:'↓';opacity:1}
.cr-table td{padding:8px 12px;border-bottom:1px solid var(--black4);color:var(--gray2);white-space:nowrap;vertical-align:middle}
.cr-table tr:last-child td{border-bottom:none}
.cr-table tr:hover td{background:rgba(255,255,255,.02)}
.cr-table .cr-num{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;color:var(--white)}
.cr-empty{padding:2.5rem;text-align:center;color:var(--gray4);font-size:12px}
/* Payment Status */
.ps-wrap{max-width:680px}
.ps-search-bar{display:flex;gap:.75rem;margin-bottom:1.5rem;align-items:flex-end}
.ps-search-bar input{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:10px 14px;font-family:inherit;font-size:14px;font-weight:700;color:var(--white);outline:none;flex:1}
.ps-search-bar input:focus{border-color:var(--yellow)}
.ps-search-bar input::placeholder{color:var(--gray4);font-weight:400}
.ps-btn{padding:10px 22px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.ps-btn:hover{background:#ffe033}
.ps-result{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden;margin-bottom:1rem}
.ps-result-hdr{padding:.85rem 1.25rem;border-bottom:1px solid var(--black4);display:flex;justify-content:space-between;align-items:center}
.ps-result-hdr .ps-pro{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--yellow)}
.ps-result-hdr .ps-payee{font-size:13px;color:var(--gray3);margin-top:2px}
.ps-rows{padding:.85rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}
.ps-row{display:flex;align-items:flex-start;gap:1rem;padding:.75rem 1rem;background:var(--black4);border-radius:var(--r)}
.ps-row-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.ps-row-body{flex:1}
.ps-row-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);margin-bottom:4px}
.ps-row-val{font-size:13px;font-weight:700;color:var(--white)}
.ps-row-sub{font-size:11px;color:var(--gray4);margin-top:2px}
.ps-badge-yes{background:var(--green-bg);color:var(--green);padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase}
.ps-badge-no{background:var(--black5);color:var(--gray4);padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase}
.ps-badge-paid{background:var(--green-bg);color:var(--green);padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase}
.ps-badge-unpaid{background:var(--red-bg);color:var(--red);padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase}
.ps-ach-detail{background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.2);border-radius:var(--r);padding:.65rem 1rem;margin-top:.4rem;font-size:11px;color:var(--gray3)}
.ps-ach-detail strong{color:var(--blue)}
.ps-no-result{padding:2rem;text-align:center;color:var(--gray4);font-size:12px}
.ps-admin-wrap{border-top:1px solid var(--black4);margin-top:1.5rem;padding-top:1.5rem;display:flex;flex-direction:column;gap:1.5rem}
.ps-admin-hdr{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.ps-admin-section{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}
.ps-admin-title{font-size:13px;font-weight:700;color:var(--white)}
.ps-admin-sub{font-size:10px;font-weight:400;color:var(--gray4);margin-left:.25rem}
.ps-admin-desc{font-size:11px;color:var(--gray4);margin-top:-.25rem}
.ps-admin-tbl{width:100%;border-collapse:collapse;font-size:12px}
.ps-admin-tbl thead tr{border-bottom:1px solid var(--black4)}
.ps-admin-tbl th{padding:5px 8px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray4)}
.ps-admin-tbl td{padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.04)}
.ps-admin-tbl tr:last-child td{border-bottom:none}
.ps-admin-th-del{width:28px}
.ps-admin-mono{font-family:monospace;font-size:12px;color:var(--white)}
.ps-admin-amt{color:var(--green)}
.ps-admin-wrong{color:#f87171}
.ps-admin-muted{color:var(--gray4);font-size:11px}
.ps-admin-type-pill{background:rgba(255,215,0,.1);color:var(--yellow);padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.04em}
.ps-admin-del{background:none;border:none;color:var(--gray4);cursor:pointer;font-size:13px;padding:2px 4px;border-radius:4px;transition:color .15s}
.ps-admin-del:hover{color:var(--red)}
.ps-admin-form{display:grid;gap:6px;align-items:flex-end}
.ps-admin-form-3{grid-template-columns:1fr 1fr 1fr auto}
.ps-admin-form-4{grid-template-columns:1fr 1fr 1fr 1fr auto}
.ps-admin-field{display:flex;flex-direction:column;gap:3px}
.ps-admin-lbl{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gray4)}
.ps-admin-inp{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%;box-sizing:border-box}
.ps-admin-inp:focus{border-color:var(--yellow)}
.ps-admin-sel{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%;cursor:pointer}
.ps-admin-sel:focus{border-color:var(--yellow)}
.ps-admin-add{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 14px;font-family:inherit;font-size:12px;font-weight:700;color:var(--white);cursor:pointer;white-space:nowrap;transition:border-color .15s}
.ps-admin-add:hover{border-color:var(--yellow);color:var(--yellow)}
.ps-admin-save-row{display:flex;justify-content:flex-end}


/* ── User Management ── */
.um-table-wrap{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);overflow:hidden;margin-bottom:1.25rem}
.um-table{width:100%;border-collapse:collapse;font-size:13px}
.um-table th{background:var(--black4);padding:10px 14px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.um-table td{padding:10px 14px;border-bottom:1px solid var(--black4);vertical-align:middle}
.um-table tr:last-child td{border-bottom:none}
.um-table tr:hover td{background:rgba(255,255,255,.02)}
.um-role-admin{background:rgba(255,215,0,.12);color:var(--yellow);padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-role-user{background:var(--black5);color:var(--gray3);padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-status-ok{color:var(--green);font-size:11px;font-weight:600}
.um-status-default{color:#fbbf24;font-size:11px;font-weight:600}
.um-btn{padding:5px 12px;border:none;border-radius:var(--r);font-family:inherit;font-size:10px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.04em}
.um-btn.yellow{background:rgba(255,215,0,.15);color:var(--yellow)}
.um-btn.yellow:hover{background:rgba(255,215,0,.25)}
.um-btn.red{background:var(--red-bg);color:var(--red)}
.um-btn.red:hover{background:rgba(239,68,68,.2)}
.um-btn.green{background:var(--green-bg);color:var(--green)}
.um-btn.green:hover{background:rgba(34,197,94,.2)}
.um-add-form{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.25rem;display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.75rem;align-items:flex-end}
.um-fg{display:flex;flex-direction:column;gap:4px}
.um-fg label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.um-fg input,.um-fg select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:8px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none}
.um-fg input:focus,.um-fg select:focus{border-color:var(--yellow)}
.um-fg select option{background:var(--black3)}
/* Force change password modal */
#pw-change-modal{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:99999;display:flex;align-items:center;justify-content:center}
.pw-modal-box{background:var(--black2);border:1px solid var(--black4);border-radius:var(--rlg);padding:2rem;width:420px;max-width:95vw}
.pw-modal-box input{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:9px 12px;font-family:inherit;font-size:13px;color:var(--white);outline:none;width:100%;margin-bottom:.75rem;box-sizing:border-box}
.pw-modal-box input:focus{border-color:var(--yellow)}
.pw-strength{height:4px;border-radius:2px;margin-bottom:.75rem;transition:all .3s}
.pw-strength.weak{background:var(--red);width:30%}
.pw-strength.fair{background:#fbbf24;width:60%}
.pw-strength.strong{background:var(--green);width:100%}
.pw-req{font-size:10px;color:var(--gray4);margin-bottom:1rem;line-height:1.7}
.pw-req span{margin-right:.75rem}
.pw-req .ok{color:var(--green)}
.pw-req .fail{color:var(--gray4)}


/* ── Role-based access ── */
.nav-locked{opacity:.35;pointer-events:none;position:relative;cursor:not-allowed !important}
.nav-locked::after{content:'🔒';position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:10px;opacity:.6}
/* ── Access Grid — hierarchical View/Edit ── */
.um-access-grid{display:flex;flex-direction:column;gap:3px;margin-top:.6rem}
.um-access-section-hdr{color:var(--gray4);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:10px 8px 3px;margin-top:4px;border-top:1px solid var(--black4)}
.um-access-section-hdr:first-child{border-top:none;margin-top:0;padding-top:4px}
.um-access-parent{border-radius:6px;overflow:hidden}
.um-access-parent.has-children{background:var(--black4)}
.um-access-row{display:flex;align-items:center;gap:6px;padding:6px 8px;background:var(--black4);border-radius:5px}
.um-access-parent.has-children .um-access-row{border-radius:0;border-bottom:1px solid rgba(255,255,255,.04)}
.um-access-row:hover{background:var(--black5)}
.um-access-label{flex:1;font-size:12px;color:var(--gray2);display:flex;align-items:center;gap:6px}
.um-toggle-btn{background:none;border:none;color:var(--gray4);cursor:pointer;font-size:10px;padding:0 2px;line-height:1;flex-shrink:0;transition:color .15s}
.um-toggle-btn:hover{color:var(--yellow)}
.um-spacer{display:inline-block;width:16px;flex-shrink:0}
.um-ve-label{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--gray4);cursor:pointer;white-space:nowrap;padding:2px 6px;border-radius:3px;user-select:none}
.um-ve-label.vis-lbl{color:#60a5fa}
.um-ve-label.vis-lbl input[type=checkbox]{accent-color:#3b82f6}
.um-ve-label:hover{color:var(--gray2)}
.um-ve-label input[type=checkbox]{accent-color:var(--yellow);width:12px;height:12px;flex-shrink:0;cursor:pointer}
.um-access-children{padding:2px 0 4px 0;background:rgba(0,0,0,.2)}
.child-row{padding:5px 8px 5px 24px;background:transparent;border-radius:0}
.child-row:hover{background:rgba(255,255,255,.03)}
.child-label{color:var(--gray3);font-size:11px}
/* legacy compat — keep old class working if anywhere referenced */
.um-access-item{display:flex;align-items:center;gap:.5rem;padding:4px 8px;border-radius:4px;background:var(--black4);font-size:11px;color:var(--gray3)}
.um-access-item input[type=checkbox]{accent-color:var(--yellow);width:13px;height:13px;flex-shrink:0}
.um-edit-modal{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9998;display:flex;align-items:flex-start;justify-content:center;padding-top:30px;overflow-y:auto}
.um-edit-box{background:var(--black2);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.75rem;width:600px;max-width:95vw;max-height:calc(100vh - 60px);overflow-y:auto}
.um-edit-box::-webkit-scrollbar{width:4px}
.um-edit-box::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.um-presence{font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:4px}
.um-presence.green{color:#22c55e}
.um-presence.yellow{color:#fbbf24}
.um-presence.grey{color:var(--gray4)}
.um-timer{font-size:10px;opacity:.7;font-variant-numeric:tabular-nums;margin-left:3px}
/* ── Marketing Materials ── */
.mkt-wrap{padding:.25rem 0}
.mkt-loading{display:flex;align-items:center;gap:.75rem;color:var(--gray4);font-size:13px;padding:2rem 0}
.mkt-spinner{width:16px;height:16px;border:2px solid var(--black4);border-top-color:var(--yellow);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

.mkt-section{margin-bottom:2rem}
.mkt-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--black4)}
.mkt-section-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gray4)}
.mkt-upload-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;background:rgba(255,215,0,.1);border:1px solid rgba(255,215,0,.2);color:var(--yellow);border-radius:var(--r);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .15s}
.mkt-upload-btn:hover{background:rgba(255,215,0,.2)}
.mkt-upload-btn svg{stroke:var(--yellow);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.mkt-list{display:flex;flex-direction:column;gap:6px}
.mkt-list-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:12px 16px;background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);transition:border-color .15s}
.mkt-list-row:hover{border-color:var(--black5)}
.mkt-list-info{flex:1;min-width:0}
.mkt-list-name{font-size:13px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.mkt-list-meta{font-size:10px;color:var(--gray4)}
.mkt-list-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}

.mkt-dl-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--r);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;text-decoration:none;border:none;transition:background .15s}
.mkt-dl-btn svg{fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.mkt-pdf-btn{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.2)}
.mkt-pdf-btn svg{stroke:#f87171}
.mkt-pdf-btn:hover{background:rgba(239,68,68,.22)}
.mkt-pptx-btn{background:rgba(251,146,60,.12);color:#fb923c;border:1px solid rgba(251,146,60,.2)}
.mkt-pptx-btn svg{stroke:#fb923c}
.mkt-pptx-btn:hover{background:rgba(251,146,60,.22)}
.mkt-del-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--red-bg);border:none;border-radius:var(--r);cursor:pointer;color:var(--red);transition:background .15s}
.mkt-del-btn svg{fill:none;stroke:var(--red);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.mkt-del-btn:hover{background:rgba(239,68,68,.2)}

.mkt-empty-sec{font-size:12px;color:var(--gray4);padding:.75rem 0;font-style:italic}
.mkt-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;color:var(--gray4);text-align:center}
.mkt-empty svg{fill:none;stroke:var(--gray4);stroke-width:1.5;width:40px;height:40px;opacity:.4}
.mkt-empty p{font-size:12px;margin:0;opacity:.7}

/* Upload Modal */
.mkt-upload-box{background:var(--black2);border:1px solid var(--black4);border-radius:var(--rlg);width:480px;max-width:95vw;overflow:hidden}
.mkt-upload-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--black4);font-size:14px;font-weight:700;color:var(--white)}
.mkt-upload-close{background:none;border:none;color:var(--gray4);font-size:16px;cursor:pointer;padding:0;line-height:1}
.mkt-upload-close:hover{color:var(--white)}
.mkt-upload-body{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}
.mkt-dropzone{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;border:2px dashed var(--black5);border-radius:var(--r);cursor:pointer;transition:border-color .15s;text-align:center}
.mkt-dropzone:hover{border-color:var(--yellow)}
.mkt-dropzone svg{fill:none;stroke:var(--gray4);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;opacity:.6}
.mkt-dropzone span{font-size:13px;color:var(--gray2)}
.mkt-dropzone small{font-size:10px;color:var(--gray4)}
.mkt-dropzone.dragover{border-color:var(--yellow);background:rgba(255,215,0,.05)}
.mkt-upload-list{display:flex;flex-direction:column;gap:4px;max-height:160px;overflow-y:auto}
.mkt-upload-file-row{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--black3);border-radius:4px;font-size:11px}
.mkt-upload-file-name{color:var(--gray2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.mkt-upload-file-size{color:var(--gray4);flex-shrink:0;margin-left:.5rem}
.mkt-upload-progress{font-size:11px;color:var(--yellow);padding:4px 0}
.mkt-upload-err{font-size:11px;color:var(--red);padding:4px 0}
.mkt-upload-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid var(--black4)}
.mkt-upload-cancel{padding:8px 18px;background:var(--black4);border:none;border-radius:var(--r);color:var(--gray2);font-size:12px;font-weight:600;cursor:pointer}
.mkt-upload-cancel:hover{background:var(--black5)}
.mkt-upload-submit{padding:8px 20px;background:var(--yellow);border:none;border-radius:var(--r);color:var(--black);font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.04em}
.mkt-upload-submit:hover{background:#e6c200}
.mkt-upload-submit:disabled{opacity:.5;cursor:not-allowed}
.um-role-leadership{background:rgba(139,92,246,.15);color:#a78bfa;padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-role-admin-assistant{background:rgba(20,184,166,.15);color:#2dd4bf;padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-role-accounting{background:rgba(251,191,36,.15);color:#fbbf24;padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-role-controller{background:rgba(245,158,11,.15);color:#f59e0b;padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-role-operations{background:rgba(59,130,246,.15);color:var(--blue);padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-role-w2{background:rgba(34,197,94,.15);color:var(--green);padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}
.um-role-1099{background:rgba(251,146,60,.15);color:#fb923c;padding:2px 9px;border-radius:20px;font-size:9px;font-weight:700;text-transform:uppercase}


/* ── Reports Database ── */
.rdb-upload-zone{background:var(--black3);border:2px dashed var(--black5);border-radius:var(--rlg);padding:2.5rem;text-align:center;cursor:pointer;transition:border-color .2s;margin-bottom:1.25rem}
.rdb-upload-zone:hover,.rdb-upload-zone.drag{border-color:var(--yellow);background:rgba(255,215,0,.04)}
.rdb-btn{padding:9px 20px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap;flex-shrink:0}
.rdb-btn:hover{background:#ffe033}
.rdb-btn.sec{background:var(--black5);color:var(--gray2)}
.rdb-btn.sec:hover{background:var(--black4);color:var(--white)}
.rdb-btn.red{background:var(--red-bg);color:var(--red)}
.rdb-file-card{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1rem 1.25rem;margin-bottom:.75rem;display:flex;align-items:center;gap:1rem}
.rdb-file-icon{width:36px;height:36px;border-radius:8px;background:var(--black5);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.rdb-file-info{flex:1;min-width:0}
.rdb-file-name{font-size:13px;font-weight:700;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rdb-file-meta{font-size:11px;color:var(--gray4);margin-top:2px}
.rdb-file-rows{font-size:11px;color:var(--green);font-weight:600;margin-top:2px}
.rdb-col-map{background:var(--black4);border-radius:var(--r);padding:.75rem 1rem;margin-top:.75rem;display:grid;grid-template-columns:1fr 1fr;gap:.4rem}
.rdb-col-row{display:flex;align-items:center;gap:.5rem;font-size:11px}
.rdb-col-detected{color:var(--gray4);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rdb-col-arrow{color:var(--black5)}
.rdb-col-mapped{color:var(--yellow);font-weight:600}
.rdb-col-sel{background:var(--black3);border:1px solid var(--black5);border-radius:4px;padding:3px 6px;font-family:inherit;font-size:10px;color:var(--white);outline:none;flex:1}
.rdb-col-sel:focus{border-color:var(--yellow)}
.rdb-col-sel option{background:var(--black3)}
/* Override styles */
.rdb-ov-record{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.1rem 1.25rem;margin-bottom:1rem}
.rdb-ov-pro{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:var(--yellow);margin-bottom:.6rem}
.rdb-ov-fields{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:.75rem}
.rdb-ov-field{background:var(--black4);border-radius:var(--r);padding:.5rem .75rem}
.rdb-ov-field-label{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);margin-bottom:3px}
.rdb-ov-field-val{font-size:12px;color:var(--white);font-weight:600}
.rdb-ov-edit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:.75rem}
.rdb-ov-inp{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:7px 10px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:100%;box-sizing:border-box}
.rdb-ov-inp:focus{border-color:var(--yellow)}
.rdb-ov-item{background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);padding:.6rem .85rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem;font-size:12px;margin-bottom:.4rem}
.rdb-ov-item-pro{font-family:'Barlow Condensed',sans-serif;font-weight:700;color:var(--yellow);min-width:70px}
.rdb-ov-item-changes{flex:1;color:var(--gray3)}
.rdb-ov-item-del{background:none;border:none;cursor:pointer;color:var(--gray4);font-size:13px;padding:2px 5px;border-radius:3px}
.rdb-ov-item-del:hover{color:var(--red);background:var(--red-bg)}



/* ── HR Records ── */
.hr-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem;flex-wrap:wrap}
.hr-tabs{display:flex;gap:.4rem;background:var(--black4);border-radius:var(--r);padding:3px}
.hr-tab{padding:6px 16px;border-radius:calc(var(--r) - 2px);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;border:none;background:none;color:var(--gray4);font-family:inherit;transition:all .15s}
.hr-tab.active{background:var(--black2);color:var(--white)}
.hr-tab.active.w2{color:var(--yellow)}
.hr-tab.active.inactive{color:var(--gray4)}
.hr-search{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:8px 14px;font-family:inherit;font-size:12px;color:var(--white);outline:none;width:220px}
.hr-search:focus{border-color:var(--yellow)}
.hr-add-btn{padding:9px 18px;background:var(--yellow);color:var(--black);border:none;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.hr-add-btn:hover{background:#ffe033}
.hr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem}
.hr-card{background:var(--black3);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.1rem 1.25rem;position:relative;transition:border-color .15s}
.hr-card:hover{border-color:var(--black5)}
.hr-card.inactive{opacity:.6}
.hr-card-top{display:flex;align-items:center;gap:.85rem;margin-bottom:.75rem}
.hr-av{width:40px;height:40px;border-radius:50%;background:var(--black5);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;color:var(--yellow);flex-shrink:0}
.hr-av.inactive{color:var(--gray4)}
.hr-name{font-size:14px;font-weight:700;color:var(--white);line-height:1.2}
.hr-code{font-size:11px;color:var(--yellow);font-weight:700;font-family:'Barlow Condensed',sans-serif;letter-spacing:.05em}
.hr-code.inactive{color:var(--gray4)}
.hr-meta{display:grid;grid-template-columns:1fr 1fr;gap:.35rem .75rem;margin-bottom:.85rem}
.hr-meta-item{font-size:11px}
.hr-meta-label{color:var(--gray4);margin-bottom:1px;font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.hr-meta-val{color:var(--gray2);font-weight:600}
.hr-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-right:4px}
.hr-badge.w2{background:rgba(255,215,0,.12);color:var(--yellow)}
.hr-badge.c1099{background:var(--blue-bg);color:var(--blue)}
.hr-badge.active{background:var(--green-bg);color:var(--green)}
.hr-badge.inactive{background:var(--black5);color:var(--gray4)}
.hr-actions{display:flex;gap:.4rem;justify-content:flex-end;padding-top:.75rem;border-top:1px solid var(--black4)}
.hr-act-btn{padding:5px 12px;border-radius:var(--r);font-family:inherit;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;border:none}
.hr-act-btn.edit{background:var(--black5);color:var(--gray2)}
.hr-act-btn.edit:hover{background:var(--black4);color:var(--white)}
.hr-act-btn.toggle{background:var(--black5);color:var(--gray2)}
.hr-act-btn.toggle:hover{background:rgba(255,215,0,.12);color:var(--yellow)}
.hr-act-btn.toggle.deactivate:hover{background:var(--red-bg);color:var(--red)}
.hr-empty{text-align:center;padding:3rem;color:var(--gray4);font-size:13px;grid-column:1/-1}
/* HR Modal */
.hr-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;align-items:center;justify-content:center}
.hr-modal.open{display:flex}
.hr-mbox{background:var(--black2);border:1px solid var(--black4);border-radius:var(--rlg);padding:1.75rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}
.hr-mbox h3{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;margin:0 0 1.25rem;color:var(--white)}
.hr-mbox h3 span{color:var(--yellow)}
.hr-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}
.hr-form-full{grid-column:1/-1}
.hr-field label{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray4);display:block;margin-bottom:4px}
.hr-field input,.hr-field select{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);padding:9px 12px;font-family:inherit;font-size:13px;color:var(--white);outline:none;width:100%;box-sizing:border-box}
.hr-field input:focus,.hr-field select:focus{border-color:var(--yellow)}
.hr-field select option{background:var(--black3)}
.hr-modal-actions{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--black4)}
.hr-modal-btn{padding:9px 22px;border-radius:var(--r);font-family:inherit;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none}
.hr-modal-btn.save{background:var(--yellow);color:var(--black)}
.hr-modal-btn.save:hover{background:#ffe033}
.hr-modal-btn.cancel{background:var(--black5);color:var(--gray2)}
.hr-modal-btn.cancel:hover{color:var(--white)}


/* ── Notifications ── */
.notif-wrap{position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--black3);border:1px solid var(--black4);transition:background .15s;flex-shrink:0}
.notif-wrap:hover{background:var(--black4)}
.notif-icon{width:16px;height:16px;color:var(--gray3);transition:color .15s}
.notif-wrap:hover .notif-icon{color:var(--white)}
.notif-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;background:var(--yellow);color:var(--black);font-size:9px;font-weight:800;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none}

.notif-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:300px;background:var(--black2);border:1px solid var(--black4);border-radius:var(--rlg);box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:9990;display:none;flex-direction:column;overflow:hidden;max-height:400px;overflow-y:auto}
.notif-dropdown.open{display:flex}
.notif-hdr{padding:.75rem 1rem .5rem;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);border-bottom:1px solid var(--black4);flex-shrink:0}
.notif-empty{padding:1.5rem 1rem;font-size:12px;color:var(--gray4);text-align:center}
.notif-item{display:flex;align-items:flex-start;gap:.6rem;padding:.75rem 1rem;border-bottom:1px solid var(--black4);transition:background .12s;cursor:default}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:var(--black3)}
.notif-item.notif-new{background:rgba(255,215,0,.04)}
.notif-dot{width:7px;height:7px;border-radius:50%;background:var(--black5);flex-shrink:0;margin-top:4px}
.notif-dot.active{background:var(--yellow)}
.notif-body{flex:1;min-width:0}
.notif-msg{font-size:12px;color:var(--gray2);line-height:1.4;margin-bottom:2px}
.notif-detail{font-size:10px;color:var(--gray4);margin-bottom:3px}
.notif-time{font-size:10px;color:var(--gray4)}
.notif-list{overflow-y:auto;max-height:320px}
.notif-list::-webkit-scrollbar{width:3px}
.notif-list::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.notif-hdr{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem .5rem;border-bottom:1px solid var(--black4);flex-shrink:0}
.notif-hdr span{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4)}
.notif-clear-all{background:none;border:none;font-size:10px;font-weight:600;color:var(--yellow);cursor:pointer;padding:2px 6px;border-radius:3px;transition:opacity .15s}
.notif-clear-all:hover{opacity:.7}
.notif-clear-all.disabled{color:var(--gray4);cursor:not-allowed;opacity:.4}
.notif-del-btn{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--gray4);cursor:pointer;padding:4px 6px;border-radius:4px;flex-shrink:0;opacity:0;font-size:12px;transition:opacity .15s,color .15s;line-height:1}
.notif-item:hover .notif-del-btn{opacity:1}
.notif-del-btn:hover{color:var(--red)}

/* Nav Updated badge */
.nav-updated-badge{display:inline-flex;align-items:center;margin-left:auto;padding:1px 6px;background:rgba(34,197,94,.15);color:#4ade80;font-size:8px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:3px;flex-shrink:0}
.ni-item .nav-updated-badge{margin-left:6px}
.ns-item .nav-updated-badge{margin-left:auto}
/* ── Settings tabs ── */
.set-tabs{display:flex;gap:.5rem;border-bottom:1px solid var(--black4);margin-bottom:1.5rem}
.set-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--gray3);font-size:12px;font-weight:600;padding:.6rem 1rem;cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}
.set-tab:hover{color:var(--white)}
.set-tab.active{color:var(--yellow);border-bottom-color:var(--yellow)}
.set-pane{display:none}
.set-pane.active{display:block}

/* ── Maintenance toggles ── */
.maint-intro{font-size:12px;color:var(--gray4);margin-bottom:1.25rem;line-height:1.5}
.maint-item-wrap{margin-bottom:3px}
.maint-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--black3);border-radius:6px}
.maint-row.child-row{background:rgba(0,0,0,.2);border-radius:4px;padding:6px 10px 6px 24px;margin-top:1px}
.maint-label{flex:1;font-size:12px;color:var(--gray2);display:flex;align-items:center;gap:6px}
.maint-label.child-label{font-size:11px;color:var(--gray3)}
.maint-expand-btn{background:none;border:none;color:var(--gray4);cursor:pointer;font-size:10px;padding:0 2px;line-height:1;flex-shrink:0}
.maint-expand-btn:hover{color:var(--yellow)}
.maint-spacer{display:inline-block;width:16px;flex-shrink:0}
.maint-children{padding:2px 0 4px;background:var(--black4);border-radius:0 0 5px 5px}

/* Toggle switch */
.maint-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}
.maint-switch input{opacity:0;width:0;height:0}
.maint-slider{position:absolute;inset:0;background:var(--black5);border-radius:20px;transition:.2s;cursor:pointer}
.maint-slider:before{content:'';position:absolute;width:14px;height:14px;left:3px;bottom:3px;background:var(--gray4);border-radius:50%;transition:.2s}
.maint-switch input:checked + .maint-slider{background:rgba(239,68,68,.3)}
.maint-switch input:checked + .maint-slider:before{transform:translateX(16px);background:#f87171}

/* Maintenance overlay on pages */
.maint-overlay{position:fixed;top:0;left:var(--sidebar);right:0;bottom:0;background:#0a0a0a;z-index:500;display:flex;align-items:center;justify-content:center;font-family:'Barlow',sans-serif}
.maint-ov-box{display:flex;flex-direction:column;align-items:center;gap:1.4rem;text-align:center;padding:3rem 2rem;max-width:420px}
.maint-ov-icon-wrap{position:relative;margin-bottom:.25rem}
.maint-ov-icon-circle{width:90px;height:90px;border-radius:50%;background:#1a1a1a;border:1px solid #2e2e2e;display:flex;align-items:center;justify-content:center}
.maint-ov-icon-i{font-size:36px;color:#FFD700}
.maint-ov-icon-badge{position:absolute;bottom:2px;right:2px;width:24px;height:24px;border-radius:50%;background:#FFD700;display:flex;align-items:center;justify-content:center;border:2px solid #0a0a0a}
.maint-ov-icon-clk{font-size:12px;color:#0a0a0a}
.maint-ov-text{display:flex;flex-direction:column;gap:.5rem}
.maint-ov-label{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#FFD700}
.maint-ov-title{font-size:26px;font-weight:800;color:#ffffff;letter-spacing:-.01em;line-height:1.25}
.maint-ov-divider{width:48px;height:2px;background:#FFD700;border-radius:2px;opacity:.7}
.maint-ov-msg{font-size:13px;color:#888;line-height:1.75;max-width:300px}
.maint-ov-footer{display:flex;align-items:center;gap:8px;margin-top:.25rem;padding:10px 20px;background:#1a1a1a;border:1px solid #2e2e2e;border-radius:6px}
.maint-ov-bell{font-size:14px;color:#FFD700}
.maint-ov-footer span{font-size:12px;color:#888;font-weight:500}

/* ── Site Lockout ── */
.lock-intro{font-size:12px;color:var(--gray4);margin-bottom:1.25rem;line-height:1.5}
.lock-main-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:14px 16px;background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);margin-bottom:1rem}
.lock-main-label{font-size:13px;font-weight:700;color:var(--white);margin-bottom:2px}
.lock-main-sub{font-size:11px;color:var(--gray4)}
.lock-msg-wrap{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.lock-msg-label{font-size:11px;color:var(--gray4);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.lock-msg-input{background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);color:var(--gray2);font-size:12px;font-family:inherit;padding:8px 12px;resize:vertical;outline:none;transition:border-color .15s}
.lock-msg-input:focus{border-color:var(--yellow)}
.lock-save-msg-btn{align-self:flex-start;padding:7px 16px;background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);color:var(--gray2);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .15s}
.lock-save-msg-btn:hover{background:var(--black5);color:var(--white)}
.lock-status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:20px;font-size:11px;font-weight:600;color:#f87171}
.lock-status-badge svg{stroke:#f87171}
.lock-status-badge.unlocked{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.2);color:#4ade80}
.lock-status-badge.unlocked svg{stroke:#4ade80}

/* Login page maintenance banner */
#lock-login-banner{display:flex;align-items:flex-start;gap:.75rem;padding:12px 16px;background:rgba(255,215,0,.08);border:1px solid rgba(255,215,0,.2);border-radius:var(--r);margin-bottom:1.25rem}
.lock-login-icon{color:var(--yellow);flex-shrink:0;margin-top:1px}
.lock-login-icon svg{stroke:var(--yellow)}
.lock-login-title{font-size:12px;font-weight:700;color:var(--yellow);margin-bottom:2px;text-transform:uppercase;letter-spacing:.06em}
.lock-login-msg{font-size:12px;color:var(--gray3);line-height:1.5}

/* Warning toast */
#lock-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);background:#1a1a1a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:14px 18px;display:flex;flex-direction:column;gap:8px;z-index:9999;box-shadow:0 4px 24px rgba(0,0,0,.6);min-width:320px;max-width:380px}
.lock-toast-top{display:flex;align-items:center;gap:8px}
.lock-toast-dot{width:8px;height:8px;border-radius:50%;background:#f87171;flex-shrink:0;animation:lock-pulse 1.5s infinite}
@keyframes lock-pulse{0%,100%{opacity:1}50%{opacity:.3}}
.lock-toast-label{font-size:10px;font-weight:800;color:#f87171;letter-spacing:.12em;text-transform:uppercase;flex:1}
.lock-toast-countdown{font-size:20px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums;line-height:1;flex-shrink:0}
.lock-toast-msg{font-size:12px;color:#888;line-height:1.5;padding-left:16px}
.lock-toast-bar{height:2px;background:#242424;border-radius:2px;overflow:hidden}
.lock-toast-bar-fill{width:100%;height:100%;background:#f87171;border-radius:2px}

/* Maintenance mode/schedule selector */
.maint-mode-row{display:flex;gap:.5rem;margin-bottom:1.25rem}
.maint-mode-opt{flex:1;padding:10px 14px;background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);cursor:pointer;transition:border-color .15s,background .15s}
.maint-mode-opt:hover{background:var(--black4)}
.maint-mode-opt.active{border-color:var(--yellow);background:rgba(255,215,0,.06)}
.maint-mode-title{font-size:12px;font-weight:700;color:var(--white);margin-bottom:2px}
.maint-mode-opt.active .maint-mode-title{color:var(--yellow)}
.maint-mode-sub{font-size:10px;color:var(--gray4)}
.maint-schedule-panel{background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);padding:14px;margin-bottom:1rem}
.maint-schedule-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}
.maint-sched-lbl{font-size:11px;color:var(--gray4);font-weight:600;white-space:nowrap}
.maint-sched-input{background:var(--black4);border:1px solid var(--black5);border-radius:var(--r);color:var(--gray2);font-size:12px;font-family:inherit;padding:7px 10px;outline:none;flex:1;min-width:180px}
.maint-sched-input:focus{border-color:var(--yellow)}
.maint-sched-btn{padding:7px 16px;background:var(--yellow);border:none;border-radius:var(--r);color:var(--black);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;white-space:nowrap;flex-shrink:0}
.maint-sched-btn:hover{opacity:.9}
.maint-sched-status{font-size:11px;color:#4ade80;margin-top:.5rem}
.maint-section-divider{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray4);padding:12px 0 6px;border-top:1px solid var(--black4);margin-top:.25rem}

/* ── Scheduled Maintenance UI ── */
.maint-schedule-panel{background:var(--black3);border:1px solid var(--black4);border-radius:var(--r);padding:14px;margin-bottom:1rem}
.maint-sched-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.maint-sched-field label{display:block;font-size:9px;font-weight:700;color:#555;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px}
.maint-sched-input-wrap{display:flex;align-items:center;background:var(--black2);border:1px solid var(--black4);border-radius:6px;overflow:hidden;transition:border-color .15s;padding-left:10px}
.maint-sched-input-wrap:focus-within{border-color:var(--yellow)}
.maint-sched-input-wrap svg{stroke:var(--gray4);flex-shrink:0}
.maint-sched-input{background:none;border:none;color:var(--gray2);font-size:12px;font-family:inherit;padding:9px 10px;outline:none;width:100%;cursor:pointer}
.maint-sched-input::-webkit-calendar-picker-indicator{filter:invert(.3);cursor:pointer}
.maint-sched-preview{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(255,215,0,.06);border:1px solid rgba(255,215,0,.15);border-radius:6px;margin-bottom:12px;font-size:11px;color:var(--gray3)}
.maint-sched-preview strong{color:var(--yellow)}
.maint-sched-actions{display:flex;align-items:center;gap:8px}
.maint-sched-hint{flex:1;display:flex;align-items:center;gap:5px;font-size:10px;color:#444}
.maint-sched-hint svg{stroke:#555;flex-shrink:0}
.maint-sched-cancel-input{padding:7px 12px;background:var(--black4);border:1px solid var(--black5);border-radius:6px;color:var(--gray4);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}
.maint-sched-cancel-input:hover{color:var(--white)}
.maint-sched-btn{padding:7px 18px;background:var(--yellow);border:none;border-radius:6px;color:var(--black);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.maint-sched-btn:hover{opacity:.9}
.maint-sched-err{font-size:11px;color:#f87171;margin-top:8px}

/* Scheduled active status card */
.maint-sched-active-card{display:flex;align-items:center;gap:8px;background:var(--black2);border:1px solid rgba(74,222,128,.15);border-radius:6px;padding:10px 14px;margin-top:10px}
.maint-sched-active-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;flex-shrink:0;animation:sched-blink 2s infinite}
@keyframes sched-blink{0%,100%{opacity:1}50%{opacity:.3}}
.maint-sched-active-text{flex:1;font-size:12px;color:var(--gray3);line-height:1.4}
.maint-sched-active-text strong{color:#4ade80}
.maint-sched-cancel-btn{background:none;border:none;color:#555;font-size:16px;cursor:pointer;line-height:1;padding:2px 4px}
.maint-sched-cancel-btn:hover{color:#f87171}

/* Countdown toast (yellow) */
#sched-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);background:#1a1a1a;border:1px solid rgba(255,215,0,.25);border-radius:8px;padding:14px 18px;display:flex;flex-direction:column;gap:8px;z-index:9999;box-shadow:0 4px 24px rgba(0,0,0,.6);min-width:320px;max-width:380px}
.sched-toast-top{display:flex;align-items:center;gap:8px}
.sched-toast-dot{width:8px;height:8px;border-radius:50%;background:#FFD700;flex-shrink:0;animation:sched-blink 1.5s infinite}
.sched-toast-label{font-size:10px;font-weight:800;color:#FFD700;letter-spacing:.12em;text-transform:uppercase;flex:1}
.sched-toast-countdown{font-size:22px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums;line-height:1;flex-shrink:0}
.sched-toast-msg{font-size:12px;color:#888;line-height:1.5;padding-left:16px}
.sched-toast-msg strong{color:#FFD700}
.sched-toast-bar{height:2px;background:#242424;border-radius:2px;overflow:hidden}
.sched-toast-bar-fill{width:100%;height:100%;background:#FFD700;border-radius:2px}

/* Scheduled section pills */
.maint-sched-section-lbl{font-size:9px;font-weight:700;color:#555;letter-spacing:.1em;text-transform:uppercase;margin:12px 0 8px}
.sched-pills-wrap{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;max-height:220px;overflow-y:auto;padding-right:4px}
.sched-pills-wrap::-webkit-scrollbar{width:3px}
.sched-pills-wrap::-webkit-scrollbar-thumb{background:var(--black5);border-radius:2px}
.sched-pill-group{display:flex;flex-direction:column;gap:3px}
.sched-pill-parent-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.sched-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--black3);border:1px solid var(--black4);border-radius:20px;font-size:10px;color:var(--gray4);cursor:pointer;user-select:none;transition:all .15s;white-space:nowrap}
.sched-pill:hover{border-color:#555;color:var(--gray2)}
.sched-pill.selected{background:rgba(255,215,0,.08);border-color:rgba(255,215,0,.3);color:var(--yellow)}
.sched-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--black5);flex-shrink:0;transition:background .15s}
.sched-pill.selected .sched-pill-dot{background:var(--yellow)}
.sched-pill-expand{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:transparent;border:1px dashed var(--black4);border-radius:20px;font-size:10px;color:#444;cursor:pointer;user-select:none;transition:all .15s;white-space:nowrap}
.sched-pill-expand:hover{border-color:#555;color:var(--gray4)}
.sched-pill-expand.open{color:var(--gray4);border-color:#444}
.sched-pill-children{display:flex;flex-wrap:wrap;gap:4px;padding:5px 0 3px 14px;border-left:1px solid var(--black4);margin-left:10px}
.sched-pill-child{font-size:10px;padding:3px 9px;background:var(--black2)}

/* Scheduled lockout */
.lock-section-divider{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#555;padding:12px 0 8px;border-top:1px solid var(--black4);margin-top:.75rem}
.lock-sched-panel{margin-bottom:.5rem}
.lock-sched-wrap:focus-within{border-color:#f87171 !important}
.lock-sched-preview{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.15);border-radius:6px;margin-bottom:12px;font-size:11px;color:var(--gray3)}
.lock-sched-preview strong{color:#f87171}
.lock-sched-btn{padding:7px 18px;background:#f87171;border:none;border-radius:6px;color:#000;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;white-space:nowrap}
.lock-sched-btn:hover{opacity:.9}
