:root{
  --ink:#0B0E17;--ink2:#1A1F2E;--ink3:#242938;
  --border:#2C3347;--border2:#353D56;
  --text:#E2E6F0;--sub:#8892AB;--dim:#4A5270;
  --blue:#3B82F6;--indigo:#6366F1;--green:#10B981;
  --amber:#F59E0B;--orange:#F97316;--red:#EF4444;--pink:#EC4899;
  --r:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--text);font-family:'Plus Jakarta Sans',sans-serif;min-height:100vh;overflow-x:hidden}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.6}

nav{position:sticky;top:0;z-index:100;background:rgba(11,14,23,.88);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 40px}
.nav-inner{max-width:1400px;margin:0 auto;height:56px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-size:15px;font-weight:700;letter-spacing:-.2px}
.nav-logo span{color:var(--blue)}
.nav-tabs{display:flex;gap:2px}
.nav-tab{background:none;border:none;color:var(--sub);font-family:inherit;font-size:13px;font-weight:500;padding:6px 14px;border-radius:6px;cursor:pointer;transition:all .15s}
.nav-tab:hover{color:var(--text);background:var(--ink2)}
.nav-tab.active{color:var(--text);background:var(--ink3)}
.nav-right{display:flex;align-items:center;gap:8px}
.badge-live{background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.25);border-radius:20px;padding:3px 10px;font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--green)}
.badge-live::before{content:'● ';font-size:8px}

.page{display:none;animation:fadeUp .25s ease}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.wrap{max-width:1400px;margin:0 auto;padding:36px 40px 80px}

.overview-hero{text-align:center;padding:48px 0 40px}
.overview-hero .eyebrow{font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:2px;text-transform:uppercase;color:var(--sub);margin-bottom:14px}
.overview-hero h1{font-size:46px;font-weight:800;letter-spacing:-1.5px;line-height:1.1}
.overview-hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--blue),var(--indigo));-webkit-background-clip:text;-webkit-text-fill-color:transparent}

.kpi-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:32px}
.kpi{background:var(--ink2);border:1px solid var(--border);border-radius:var(--r);padding:20px 22px;transition:border-color .2s}
.kpi:hover{border-color:var(--border2)}
.kpi .num{font-size:38px;font-weight:800;font-family:'JetBrains Mono',monospace;line-height:1;letter-spacing:-1px}
.kpi .lbl{font-size:11px;color:var(--sub);margin-top:6px;font-weight:500;letter-spacing:.3px}
.kpi .sub-note{font-size:10px;color:var(--dim);margin-top:4px;font-family:'JetBrains Mono',monospace}
.kpi.k-blue .num{color:var(--blue)}.kpi.k-red .num{color:var(--red)}.kpi.k-amber .num{color:var(--amber)}.kpi.k-orange .num{color:var(--orange)}.kpi.k-green .num{color:var(--green)}.kpi.k-pink .num{color:var(--pink)}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}
.full-col{margin-bottom:16px}
.card{background:var(--ink2);border:1px solid var(--border);border-radius:var(--r);padding:22px 24px}
.card-title{font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:var(--sub);margin-bottom:18px}

.dept-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.dept-row:last-child{margin-bottom:0}
.dept-name{font-size:12px;font-weight:500;width:160px;flex-shrink:0;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dept-bar-wrap{flex:1;background:var(--ink3);border-radius:4px;height:20px;overflow:hidden}
.dept-bar{height:100%;border-radius:4px;display:flex;align-items:center;padding-left:8px;transition:width .6s cubic-bezier(.22,1,.36,1)}
.dept-bar .bar-val{font-size:10px;font-family:'JetBrains Mono',monospace;color:#fff;font-weight:500}
.dept-flag{font-size:10px;font-family:'JetBrains Mono',monospace;width:38px;text-align:right;flex-shrink:0}

.donut-wrap{display:flex;align-items:center;gap:24px;padding:8px 0}
.donut-svg{flex-shrink:0}
.donut-legend{flex:1}
.legend-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.legend-row:last-child{margin-bottom:0}
.legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
.legend-label{font-size:12px;color:var(--sub);flex:1}
.legend-val{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:500}

.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.cat-block{background:var(--ink3);border:1px solid var(--border);border-radius:8px;padding:14px 16px}
.cat-block .cat-n{font-size:26px;font-weight:800;font-family:'JetBrains Mono',monospace;line-height:1}
.cat-block .cat-l{font-size:10px;color:var(--sub);margin-top:5px;font-weight:500}
.cat-block .cat-bar{height:3px;border-radius:2px;margin-top:10px}

.flag-table{width:100%;border-collapse:collapse}
.flag-table th{font-size:10px;font-family:'JetBrains Mono',monospace;letter-spacing:1px;text-transform:uppercase;color:var(--dim);padding:0 12px 10px;text-align:left;border-bottom:1px solid var(--border)}
.flag-table td{padding:11px 12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.flag-table tr:last-child td{border-bottom:none}
.flag-table tr:hover td{background:rgba(255,255,255,.02)}
.risk-pill{display:inline-flex;align-items:center;gap:5px;border-radius:20px;padding:3px 10px;font-size:10px;font-family:'JetBrains Mono',monospace;font-weight:500}
.risk-pill.CRITICAL{background:rgba(236,72,153,.12);color:var(--pink);border:1px solid rgba(236,72,153,.25)}
.risk-pill.HIGH{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.risk-pill.MEDIUM_HIGH{background:rgba(249,115,22,.1);color:var(--orange);border:1px solid rgba(249,115,22,.2)}
.risk-pill.MEDIUM{background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.risk-pill.STANDARD{background:rgba(59,130,246,.1);color:var(--blue);border:1px solid rgba(59,130,246,.2)}
.risk-pill.LOW{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.2)}

.lookup-header{padding:36px 0 28px;text-align:center}
.lookup-header h2{font-size:30px;font-weight:800;letter-spacing:-0.8px}
.lookup-header p{font-size:14px;color:var(--sub);margin-top:8px}
.search-bar-wrap{display:flex;gap:12px;margin-bottom:28px;max-width:760px;margin-left:auto;margin-right:auto}
.search-outer{flex:1;position:relative}
.search-outer input{width:100%;background:var(--ink2);border:1.5px solid var(--border2);border-radius:var(--r);color:var(--text);font-family:inherit;font-size:14px;padding:13px 16px 13px 44px;outline:none;transition:border-color .2s}
.search-outer input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.search-outer .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--sub);font-size:16px;pointer-events:none}
.dept-sel{background:var(--ink2);border:1.5px solid var(--border2);border-radius:var(--r);color:var(--text);font-family:inherit;font-size:13px;padding:13px 36px 13px 14px;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238892AB' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color .2s;min-width:200px}
.dept-sel:focus{border-color:var(--blue)}
.dept-sel option{background:#1A1F2E}

.results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:20px}
.user-thumb{background:var(--ink2);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;cursor:pointer;transition:all .15s}
.user-thumb:hover{border-color:var(--blue);transform:translateY(-1px);box-shadow:0 4px 16px rgba(59,130,246,.1)}
.user-thumb.selected{border-color:var(--blue);background:rgba(59,130,246,.06)}
.thumb-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.thumb-av{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.thumb-name{font-size:13px;font-weight:600;line-height:1.3}
.thumb-dept{font-size:10px;color:var(--sub);margin-top:1px}
.thumb-chips{display:flex;gap:5px;flex-wrap:wrap}
.mini-chip{font-size:9px;font-family:'JetBrains Mono',monospace;padding:2px 7px;border-radius:4px;background:var(--ink3);color:var(--sub);border:1px solid var(--border)}

.detail-panel{background:var(--ink2);border:1px solid var(--border2);border-radius:14px;overflow:hidden;animation:fadeUp .25s ease}
.detail-hero{padding:28px 32px;display:flex;align-items:flex-start;gap:20px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.detail-av{width:64px;height:64px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;flex-shrink:0}
.detail-info h2{font-size:22px;font-weight:800;letter-spacing:-.4px}
.detail-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.meta-chip{display:inline-flex;align-items:center;gap:6px;background:var(--ink3);border:1px solid var(--border2);border-radius:20px;padding:4px 12px;font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--sub)}
.meta-chip .dot{width:7px;height:7px;border-radius:50%}
.detail-risk{margin-left:auto;flex-shrink:0;padding:8px 18px;border-radius:10px;font-size:12px;font-weight:700;font-family:'JetBrains Mono',monospace;letter-spacing:.3px}
.detail-risk.CRITICAL{background:rgba(236,72,153,.12);color:var(--pink);border:1px solid rgba(236,72,153,.25)}
.detail-risk.HIGH{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.detail-risk.MEDIUM_HIGH{background:rgba(249,115,22,.1);color:var(--orange);border:1px solid rgba(249,115,22,.2)}
.detail-risk.MEDIUM{background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.detail-risk.STANDARD{background:rgba(59,130,246,.1);color:var(--blue);border:1px solid rgba(59,130,246,.2)}
.detail-risk.LOW{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.2)}

.pset-filter-row{padding:14px 32px;border-bottom:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.pset-filter-row .flbl{font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--dim);letter-spacing:1px;margin-right:4px}
.pf-btn{background:transparent;border:1px solid var(--border2);border-radius:20px;padding:4px 12px;font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--sub);cursor:pointer;transition:all .15s}
.pf-btn:hover{border-color:var(--blue);color:var(--blue)}
.pf-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}

.pset-section{padding:24px 32px}
.pset-section h3{font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:var(--sub);margin-bottom:16px}
.pset-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:10px}
.pc{background:var(--ink);border:1px solid var(--border);border-radius:10px;padding:14px 16px;position:relative;overflow:hidden;transition:border-color .15s,transform .15s}
.pc:hover{border-color:var(--border2);transform:translateY(-1px)}
.pc-stripe{position:absolute;top:0;left:0;right:0;height:3px}
.pc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.pc-name{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text);word-break:break-all;line-height:1.5;flex:1}
.pc-tag{font-size:9px;font-family:'JetBrains Mono',monospace;padding:2px 8px;border-radius:4px;flex-shrink:0;white-space:nowrap}
.pc-label{font-size:11px;color:var(--sub);margin-bottom:10px;line-height:1.4}
.crud-pills{display:flex;gap:4px;flex-wrap:wrap}
.cp{font-family:'JetBrains Mono',monospace;font-size:9px;padding:2px 7px;border-radius:3px;border:1px solid}
.cp.on{background:rgba(16,185,129,.1);color:var(--green);border-color:rgba(16,185,129,.25)}
.cp.off{background:rgba(255,255,255,.03);color:var(--dim);border-color:rgba(255,255,255,.06);text-decoration:line-through}
.pc-flag{margin-top:10px;background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.2);border-radius:6px;padding:7px 10px;font-size:10px;color:var(--red);line-height:1.5}
.rdot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:2px}
.rdot.CRITICAL{background:var(--pink);box-shadow:0 0 6px var(--pink)}.rdot.HIGH{background:var(--red)}.rdot.MEDIUM_HIGH{background:var(--orange)}.rdot.MEDIUM{background:var(--amber)}.rdot.STANDARD{background:var(--blue)}.rdot.LOW{background:var(--green)}

.empty-lookup{text-align:center;padding:72px 20px;color:var(--dim)}
.empty-lookup .ico{font-size:40px;margin-bottom:14px;opacity:.4}
.empty-lookup h3{font-size:17px;font-weight:600;color:var(--sub)}
.empty-lookup p{font-size:13px;margin-top:6px}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

@media(max-width:900px){.kpi-strip{grid-template-columns:repeat(3,1fr)}.two-col,.three-col{grid-template-columns:1fr}.cat-grid{grid-template-columns:repeat(2,1fr)}.wrap{padding:24px 20px 60px}}

/* Review Mode */
.cp.editable{cursor:pointer;transition:all .15s;user-select:none}
.cp.editable:hover{transform:scale(1.08);border-color:var(--blue);box-shadow:0 0 0 2px rgba(79,142,247,.2)}
.cp.modified{position:relative;border-color:var(--amber)!important;box-shadow:0 0 0 1px rgba(245,158,11,.4)}
.cp.modified::after{content:'';position:absolute;top:-3px;right:-3px;width:6px;height:6px;background:var(--amber);border-radius:50%;box-shadow:0 0 4px var(--amber)}

.instr{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;background:var(--ink);border:1px solid var(--border);border-radius:10px;padding:14px 20px;margin-bottom:20px}
.instr-hint{font-size:12px;color:var(--sub);font-weight:500;display:flex;align-items:center;gap:8px}
.instr-hint::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);box-shadow:0 0 8px rgba(79,142,247,.5);animation:instr-pulse 2s ease-in-out infinite}
@keyframes instr-pulse{0%,100%{opacity:.4}50%{opacity:1}}
.instr-demos{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.instr-demo{display:flex;align-items:center;gap:8px}
.instr-demo .cp{font-size:10px;padding:3px 8px}
.instr-arr{color:var(--dim);font-size:12px;font-family:'JetBrains Mono',monospace}
.instr-tag{font-size:10px;font-family:'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-left:4px}

.bulk-bar{background:linear-gradient(135deg,rgba(79,142,247,.1),rgba(123,95,232,.08));border:1px solid rgba(79,142,247,.3);border-radius:10px;padding:12px 16px;margin:16px 0 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.bulk-bar-left{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text)}
.bulk-bar-icon{width:28px;height:28px;border-radius:8px;flex-shrink:0;background:rgba(79,142,247,.2);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:14px}
.bulk-bar-text strong{color:var(--blue);font-weight:600}
.bulk-btn{background:rgba(79,142,247,.2);color:#93B8FA;border:1px solid rgba(79,142,247,.4);border-radius:6px;padding:8px 14px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}
.bulk-btn:hover{background:rgba(79,142,247,.3);border-color:var(--blue)}
.bulk-modal{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:48px 20px;overflow-y:auto}
.bulk-modal.open{display:flex}
.bulk-box{background:var(--ink2);border:1px solid var(--border);border-radius:14px;max-width:600px;width:100%;max-height:calc(100vh - 96px);display:flex;flex-direction:column}
.bulk-head{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:12px}
.bulk-head h3{margin:0;font-size:16px;color:var(--text)}
.bulk-close{background:transparent;border:none;color:var(--sub);cursor:pointer;font-size:22px;line-height:1;padding:4px 8px;border-radius:4px}
.bulk-close:hover{background:var(--ink3);color:var(--text)}
.bulk-body{padding:20px 24px;overflow-y:auto;flex:1}
.bulk-section{margin-bottom:18px}.bulk-section:last-child{margin-bottom:0}
.bulk-section-title{font-size:10px;font-family:'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:8px}
.bulk-changes{background:var(--ink);border:1px solid var(--border);border-radius:8px;padding:10px 14px}
.bulk-change{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:12px}
.bulk-change:not(:last-child){border-bottom:1px solid var(--border)}
.bulk-change-obj{font-weight:600;color:var(--text);min-width:90px;display:flex;align-items:center;gap:6px}
.bulk-change-diffs{display:flex;gap:6px;flex-wrap:wrap}
.bulk-change-diffs span{font-family:'JetBrains Mono',monospace;font-size:10px;background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.25);padding:2px 7px;border-radius:4px}
.bulk-users{background:var(--ink);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:12px;line-height:1.7;color:var(--sub);max-height:160px;overflow-y:auto}
.bulk-user-chip{display:inline-block;background:var(--ink3);border:1px solid var(--border);border-radius:4px;padding:2px 8px;margin:2px 4px 2px 0;font-size:11px;color:var(--text)}
.bulk-foot{padding:14px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.bulk-foot button{background:var(--ink);border:1px solid var(--border);border-radius:6px;padding:8px 14px;color:var(--text);font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s}
.bulk-foot button:hover{border-color:var(--border2);background:var(--ink2)}
.bulk-foot button.primary{background:rgba(79,142,247,.2);border-color:rgba(79,142,247,.4);color:#93B8FA}
.bulk-foot button.primary:hover{background:rgba(79,142,247,.3);border-color:var(--blue)}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;pointer-events:none;background:var(--ink2);border:1px solid rgba(16,185,129,.4);color:var(--text);padding:12px 20px;border-radius:10px;font-size:13px;z-index:1001;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;box-shadow:0 10px 40px rgba(0,0,0,.4);display:flex;align-items:center;gap:10px}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto}
.toast-icon{width:22px;height:22px;border-radius:50%;background:rgba(16,185,129,.15);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:13px}

.reset-btn{background:rgba(239,68,68,.08);color:#FCA5A5;border:1px solid rgba(239,68,68,.3);border-radius:4px;padding:2px 8px;font-size:9px;font-family:'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;margin-left:6px;transition:all .15s}
.reset-btn:hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.5);color:#fff}

.cfm-modal{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1002;display:none;align-items:center;justify-content:center;padding:20px}
.cfm-modal.open{display:flex}
.cfm-box{background:var(--ink2);border:1px solid var(--border);border-radius:12px;max-width:440px;width:100%}
.cfm-head{padding:18px 22px 6px;font-size:15px;font-weight:600;color:var(--text)}
.cfm-body{padding:6px 22px 18px;font-size:13px;color:var(--sub);line-height:1.55}
.cfm-body strong{color:var(--text)}
.cfm-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.cfm-foot button{border-radius:6px;padding:8px 14px;font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s}
.cfm-foot .cfm-cancel{background:var(--ink);border:1px solid var(--border);color:var(--text)}
.cfm-foot .cfm-cancel:hover{background:var(--ink3)}
.cfm-foot .cfm-confirm{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.4);color:#FCA5A5}
.cfm-foot .cfm-confirm:hover{background:rgba(239,68,68,.25);border-color:rgba(239,68,68,.6)}

/* ── APP SHELL ADDITIONS ─────────────────────────────────────────── */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(59,130,246,.08) 0%,transparent 70%)}
.login-card{width:100%;max-width:420px;background:var(--ink2);border:1px solid var(--border);border-radius:16px;overflow:hidden}
.login-hero{padding:40px 40px 32px;background:linear-gradient(135deg,rgba(59,130,246,.06),rgba(99,102,241,.04));border-bottom:1px solid var(--border);text-align:center}
.login-logo{display:inline-flex;align-items:center;gap:10px;margin-bottom:24px}
.login-logo-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--blue),var(--indigo));display:flex;align-items:center;justify-content:center;font-size:18px}
.login-logo-text{font-size:15px;font-weight:700;letter-spacing:-.2px}
.login-logo-text span{color:var(--blue)}
.login-hero h1{font-size:22px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px}
.login-hero p{font-size:13px;color:var(--sub);line-height:1.5}
.login-form{padding:32px 40px 40px}
.form-group{margin-bottom:18px}
.form-label{font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:.08em;color:var(--sub);text-transform:uppercase;display:block;margin-bottom:7px}
.form-input{width:100%;background:var(--ink3);border:1.5px solid var(--border2);border-radius:8px;color:var(--text);font-family:inherit;font-size:14px;padding:11px 14px;outline:none;transition:border-color .2s,box-shadow .2s}
.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.12)}
.form-input::placeholder{color:var(--dim)}
.form-input.error{border-color:var(--red)}
.login-btn{width:100%;background:var(--blue);border:none;border-radius:8px;color:#fff;font-family:inherit;font-size:14px;font-weight:600;padding:12px;cursor:pointer;transition:all .2s;margin-top:4px}
.login-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 16px rgba(59,130,246,.3)}
.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.login-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--red);margin-bottom:16px;display:none}
.login-error.show{display:block}
.role-hint{margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.role-hint p{font-size:11px;color:var(--dim);text-align:center;margin-bottom:12px;font-family:'JetBrains Mono',monospace;letter-spacing:.05em}
.role-chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.role-chip{font-size:10px;font-family:'JetBrains Mono',monospace;padding:4px 12px;border-radius:20px;cursor:pointer;transition:all .15s;border:1px solid var(--border2);color:var(--sub);background:transparent}
.role-chip:hover{border-color:var(--blue);color:var(--blue)}
.role-chip.admin{border-color:rgba(236,72,153,.3);color:var(--pink)}
.role-chip.manager{border-color:rgba(59,130,246,.3);color:var(--blue)}

#app{display:none;height:100vh;overflow:hidden}
#app.visible{display:flex}
.sidebar{width:240px;flex-shrink:0;background:var(--ink2);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;overflow:hidden}
.sidebar-top{padding:20px 16px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar-logo{display:flex;align-items:center;gap:9px;margin-bottom:16px}
.sidebar-logo-icon{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,var(--blue),var(--indigo));display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.sidebar-logo-text{font-size:13px;font-weight:700;letter-spacing:-.2px}
.sidebar-logo-text span{color:var(--blue)}
.user-badge{display:flex;align-items:center;gap:9px;background:var(--ink3);border:1px solid var(--border);border-radius:8px;padding:9px 11px}
.user-av{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.user-info{flex:1;min-width:0}
.user-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;font-family:'JetBrains Mono',monospace;margin-top:1px}
.user-role.admin{color:var(--pink)}
.user-role.manager{color:var(--blue)}
.sidebar-nav{flex:1;overflow-y:auto;padding:12px 8px}
.nav-section-label{font-size:9px;font-family:'JetBrains Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);padding:0 8px;margin:16px 0 6px}
.nav-section-label:first-child{margin-top:4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;cursor:pointer;transition:all .15s;margin-bottom:1px;border:none;background:transparent;color:var(--sub);font-family:inherit;font-size:13px;font-weight:500;width:100%;text-align:left}
.nav-item:hover{background:var(--ink3);color:var(--text)}
.nav-item.active{background:rgba(59,130,246,.1);color:var(--blue)}
.nav-icon{font-size:15px;width:18px;text-align:center;flex-shrink:0}
.nav-badge{margin-left:auto;font-size:9px;font-family:'JetBrains Mono',monospace;padding:2px 7px;border-radius:10px}
.nav-badge.red{background:rgba(239,68,68,.15);color:var(--red)}
.nav-badge.amber{background:rgba(245,158,11,.15);color:var(--amber)}
.nav-badge.blue{background:rgba(59,130,246,.15);color:var(--blue)}
.sidebar-bottom{padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}
.logout-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:7px;border:none;background:transparent;color:var(--dim);font-family:inherit;font-size:12px;cursor:pointer;transition:all .15s}
.logout-btn:hover{background:rgba(239,68,68,.08);color:var(--red)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:52px;border-bottom:1px solid var(--border);background:rgba(11,14,23,.9);backdrop-filter:blur(12px);display:flex;align-items:center;padding:0 28px;gap:16px;flex-shrink:0}
.topbar-title{font-size:14px;font-weight:600;letter-spacing:-.2px}
.topbar-sub{font-size:11px;color:var(--sub);font-family:'JetBrains Mono',monospace}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.live-badge{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);border-radius:20px;padding:3px 10px;font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--green)}
.live-badge::before{content:'● ';font-size:7px}
.content{flex:1;overflow-y:auto;padding:28px 32px 60px}

/* Task + Approval + Criteria + Log styles */
.action-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;border:none;font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}
.action-btn.flag{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.action-btn.flag:hover{background:rgba(239,68,68,.18)}
.action-btn.assign{background:rgba(59,130,246,.1);color:var(--blue);border:1px solid rgba(59,130,246,.2)}
.action-btn.assign:hover{background:rgba(59,130,246,.18)}
.action-btn.approve{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.2)}
.action-btn.approve:hover{background:rgba(16,185,129,.18)}
.action-btn.remove{background:rgba(249,115,22,.1);color:var(--orange);border:1px solid rgba(249,115,22,.2)}
.admin-only{display:none}
.task-card{background:var(--ink2);border:1px solid var(--border);border-radius:10px;padding:16px 18px;margin-bottom:10px;transition:border-color .15s}
.task-card:hover{border-color:var(--border2)}
.task-card.done{opacity:.6}
.task-card-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.task-check{width:18px;height:18px;border-radius:5px;border:2px solid var(--border2);cursor:pointer;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.task-check.checked{background:var(--green);border-color:var(--green);color:#fff;font-size:10px}
.task-title{font-size:13px;font-weight:600;line-height:1.4;flex:1}
.task-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.task-tag{font-size:10px;font-family:'JetBrains Mono',monospace;padding:2px 8px;border-radius:4px;background:var(--ink3);border:1px solid var(--border);color:var(--sub)}
.task-due{font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--dim)}
.task-due.overdue{color:var(--red)}
.ac-item{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:var(--ink3);border-radius:8px;margin-bottom:8px;border:1px solid var(--border);transition:border-color .15s}
.ac-item:hover{border-color:var(--border2)}
.ac-status{width:22px;height:22px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;margin-top:1px}
.ac-status.open{background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.ac-status.progress{background:rgba(59,130,246,.1);color:var(--blue);border:1px solid rgba(59,130,246,.2)}
.ac-status.done{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.2)}
.ac-body{flex:1}
.ac-title{font-size:13px;font-weight:600;margin-bottom:4px}
.ac-owner{font-size:11px;color:var(--sub);font-family:'JetBrains Mono',monospace}
.log-entry{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.log-entry:last-child{border-bottom:none}
.log-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.log-content{flex:1}
.log-text{font-size:12px;color:var(--text);line-height:1.5}
.log-time{font-size:10px;font-family:'JetBrains Mono',monospace;color:var(--dim);margin-top:2px}
.data-table{width:100%;border-collapse:collapse}
.data-table th{font-size:10px;font-family:'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);padding:0 14px 10px;text-align:left;border-bottom:1px solid var(--border)}
.data-table td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(255,255,255,.02)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:24px}
.modal-overlay.open{display:flex}
.modal{background:var(--ink2);border:1px solid var(--border2);border-radius:14px;width:100%;max-width:480px;overflow:hidden;animation:fadeUp .2s ease}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:15px;font-weight:700}
.modal-close{background:none;border:none;color:var(--sub);font-size:18px;cursor:pointer;padding:4px;line-height:1}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px 24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.form-group-m{margin-bottom:16px}
.form-label-m{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--sub);display:block;margin-bottom:6px;letter-spacing:.05em}
.form-input-m{width:100%;background:var(--ink3);border:1.5px solid var(--border2);border-radius:7px;color:var(--text);font-family:inherit;font-size:13px;padding:9px 12px;outline:none;transition:border-color .2s}
.form-input-m:focus{border-color:var(--blue)}
.form-select-m{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238892AB' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}
.form-select-m option{background:#1A1F2E}
.btn-primary{background:var(--blue);border:none;border-radius:7px;color:#fff;font-family:inherit;font-size:13px;font-weight:600;padding:9px 18px;cursor:pointer;transition:all .2s}
.btn-primary:hover{background:#2563eb}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;background:var(--blue)}
.btn-ghost{background:transparent;border:1px solid var(--border2);border-radius:7px;color:var(--sub);font-family:inherit;font-size:13px;padding:9px 18px;cursor:pointer;transition:all .2s}
.btn-ghost:hover{color:var(--text)}
.filter-row{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.filter-btn{background:transparent;border:1px solid var(--border2);border-radius:20px;padding:5px 13px;font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--sub);cursor:pointer;transition:all .15s}
.filter-btn:hover{border-color:var(--blue);color:var(--blue)}
.filter-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}
.empty-state{text-align:center;padding:60px 20px;color:var(--dim)}
.empty-state .ico{font-size:36px;margin-bottom:12px;opacity:.4}
.empty-state h3{font-size:16px;font-weight:600;color:var(--sub)}
.empty-state p{font-size:12px;margin-top:5px}
@media(max-width:900px){.sidebar{display:none}.content{padding:16px 16px 40px}}

/* ── LOGIN TABS (Task 7) ───────────────────────────────────────────────── */
.login-tabs{display:flex;gap:8px;margin-bottom:8px}
.login-tab{flex:1;padding:10px 8px;border-radius:8px;border:1px solid var(--border);background:var(--ink3);color:var(--sub);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.02em}
.login-tab:hover{border-color:var(--border2);color:var(--text)}
.login-tab.admin.active{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.35);color:var(--red)}
.login-tab.manager.active{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.35);color:var(--blue)}
.login-role-hint{font-size:10px;color:var(--dim);font-family:'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;text-align:center}

/* ── MANAGER REQUEST SECTION (Task 9) ─────────────────────────────────── */
.mgr-request-section{border-top:1px solid var(--border);padding:20px 32px 24px}
.mgr-request-title{font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.mgr-viewonly{font-size:12px;color:var(--dim);font-style:italic;padding:12px 0}
.mgr-changes-summary{background:var(--ink3);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:14px;font-size:12px;color:var(--sub)}
.mgr-changes-summary .chg-row{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid var(--border)}
.mgr-changes-summary .chg-row:last-child{border-bottom:none}
.mgr-no-changes{font-size:12px;color:var(--dim);font-style:italic}
.mgr-reason-label{font-size:11px;color:var(--sub);margin-bottom:6px;font-weight:500}
.mgr-reason-input{width:100%;background:var(--ink3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:12px;padding:10px 12px;resize:vertical;min-height:72px;margin-bottom:14px}
.mgr-reason-input:focus{outline:none;border-color:var(--amber)}
.mgr-actions{display:flex;gap:8px;justify-content:flex-end}
.mgr-cancel-btn{background:transparent;border:1px solid var(--border);color:var(--sub);border-radius:6px;padding:8px 16px;font-size:12px;font-family:inherit;cursor:pointer;transition:all .2s}
.mgr-cancel-btn:hover{border-color:var(--border2);color:var(--text)}
.mgr-submit-btn{background:var(--amber);border:none;color:#000;border-radius:6px;padding:8px 18px;font-size:12px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s}
.mgr-submit-btn:hover{background:#d97706}
.mgr-submit-btn:disabled{opacity:.5;cursor:not-allowed}

/* ── REQUESTED pset pill state (Task 9) ──────────────────────────────── */
.cp.requested{background:rgba(245,158,11,.18)!important;color:var(--amber)!important;border-color:rgba(245,158,11,.4)!important}
.cp.mgr-selectable{cursor:pointer}
.cp.mgr-selectable:hover{opacity:.8}

/* ── ADMIN APPROVAL PORTAL (Task 10) ─────────────────────────────────── */
.approvals-section-title{font-size:11px;font-family:'JetBrains Mono',monospace;letter-spacing:1.5px;text-transform:uppercase;color:var(--sub);margin:20px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.approvals-section-title:first-child{margin-top:0}
.req-card{background:var(--ink2);border:1px solid var(--border);border-radius:10px;padding:16px 20px;margin-bottom:10px}
.req-card.pending{border-color:var(--border2)}
.req-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.req-card-meta{font-size:11px;color:var(--dim);font-family:'JetBrains Mono',monospace;margin-top:4px}
.req-status{font-size:10px;font-family:'JetBrains Mono',monospace;padding:2px 8px;border-radius:4px;font-weight:600;flex-shrink:0}
.req-status.pending{background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.25)}
.req-status.approved{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.25)}
.req-status.rejected{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.25)}
.req-changes{background:var(--ink3);border-radius:6px;padding:10px 12px;margin:10px 0;font-size:11px;font-family:'JetBrains Mono',monospace}
.req-change-row{display:flex;align-items:center;gap:6px;padding:2px 0;color:var(--sub)}
.req-change-row .obj{color:var(--text);font-weight:600}
.req-change-row .arrow{color:var(--dim)}
.req-reason{font-size:12px;color:var(--sub);font-style:italic;margin:8px 0;line-height:1.5}
.req-admin-comment{font-size:11px;color:var(--red);background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.15);border-radius:6px;padding:8px 10px;margin-top:8px}
.req-actions{display:flex;gap:8px;margin-top:12px;justify-content:flex-end}
.req-approve-btn{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.3);color:var(--green);border-radius:6px;padding:6px 14px;font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}
.req-approve-btn:hover{background:rgba(16,185,129,.25)}
.req-reject-btn{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:var(--red);border-radius:6px;padding:6px 14px;font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}
.req-reject-btn:hover{background:rgba(239,68,68,.2)}

/* ── REJECT REASON MODAL ─────────────────────────────────────────────── */
.reject-modal-body{padding:4px 0 12px}
.reject-reason-input{width:100%;background:var(--ink3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:12px;padding:10px 12px;resize:vertical;min-height:72px;margin-top:10px}
.reject-reason-input:focus{outline:none;border-color:var(--red)}

/* ── PERMISSION REQUEST MODAL ────────────────────────────────────────── */
.perm-req-radio{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--ink3);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;cursor:pointer;font-size:13px;color:var(--sub);transition:border-color .15s,background .15s}
.perm-req-radio:hover{border-color:var(--border2);color:var(--text)}
.perm-req-radio input[type="radio"]{margin-top:2px;accent-color:var(--blue);flex-shrink:0;width:15px;height:15px}
.perm-req-radio strong{color:var(--text)}
.perm-req-summary-box{background:var(--ink3);border:1px solid var(--border);border-radius:8px;padding:12px 14px;font-size:12px;color:var(--sub);line-height:1.8}
.perm-req-summary-box strong{color:var(--text)}

/* ── BATCH FLOW: pill selection states ───────────────────────────────── */
.cp.requested-add{background:rgba(245,158,11,.18)!important;color:var(--amber)!important;border:1.5px dashed rgba(245,158,11,.6)!important;cursor:pointer;font-weight:700}
.cp.requested-rem{background:rgba(239,68,68,.12)!important;color:var(--red)!important;border:1.5px dashed rgba(239,68,68,.5)!important;cursor:pointer;font-weight:700}
.cp.mgr-selectable{cursor:pointer;transition:all .15s;user-select:none}
.cp.mgr-selectable:hover{transform:scale(1.08);border-color:var(--amber);box-shadow:0 0 0 2px rgba(245,158,11,.15)}

/* ── BATCH FLOW: sticky action bar ───────────────────────────────────── */
.mgr-action-bar{position:fixed;bottom:0;left:240px;right:0;background:rgba(17,22,36,.97);border-top:1px solid rgba(245,158,11,.35);backdrop-filter:blur(12px);padding:12px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;z-index:200;box-shadow:0 -4px 24px rgba(0,0,0,.4)}
.mgr-bar-label{font-size:13px;font-weight:700;color:var(--amber)}
.mgr-bar-sub{font-size:11px;color:var(--sub);margin-top:2px}
.mgr-bar-actions{display:flex;gap:8px;flex-shrink:0}
.mgr-bar-clear{background:transparent;border:1px solid var(--border2);border-radius:6px;color:var(--sub);font-family:inherit;font-size:12px;padding:7px 14px;cursor:pointer;transition:all .15s}
.mgr-bar-clear:hover{border-color:var(--red);color:var(--red)}
.mgr-bar-submit{background:var(--amber);border:none;border-radius:6px;color:#000;font-family:inherit;font-size:12px;font-weight:700;padding:7px 18px;cursor:pointer;transition:all .15s}
.mgr-bar-submit:hover{background:#d97706;transform:translateY(-1px)}

/* ── BATCH FLOW: modal changes list ──────────────────────────────────── */
.batch-changes-box{background:var(--ink3);border:1px solid var(--border);border-radius:8px;padding:10px 14px}
.batch-obj-block{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.batch-obj-block:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.batch-obj{font-size:12px;font-weight:700;color:var(--text);display:block;margin-bottom:5px}
.batch-change-row{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-family:'JetBrains Mono',monospace;background:var(--ink);border:1px solid var(--border);border-radius:4px;padding:2px 8px;margin:2px 4px 2px 0}
.batch-arrow{font-weight:700;font-size:13px}
@media(max-width:900px){.mgr-action-bar{left:0}}

/* ── OBJECT PERM: filter & group-by-type ─────────────────────────────── */
.obj-filter-sel{background:var(--ink2);color:var(--text);border:1px solid var(--border);border-radius:4px;font-size:10px;padding:3px 8px;cursor:pointer;font-family:inherit;outline:none;transition:border-color .15s}
.obj-filter-sel:hover,.obj-filter-sel:focus{border-color:var(--blue)}
.obj-type-header{font-size:9px;font-family:'JetBrains Mono',monospace;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px}
.obj-type-count{color:var(--sub)}
