:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f6f7fb;--surface:#fff;--surface-2:#eef1f7;--border:#d8dde8;--text:#151821;--muted:#687084;--accent:#5865f2;--accent-strong:#3642c7;--success:#087f5b;--warning:#b76e00;--danger:#c92a2a;--info:#1864ab;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}.static-login-fallback{z-index:9999;color:#fff;background:#5865f2;border-radius:8px;min-height:36px;padding:8px 12px;font:14px Inter,ui-sans-serif,system-ui,sans-serif;text-decoration:none;position:fixed;top:12px;right:12px}body.react-ready .static-login-fallback,#root:not(:empty)~.static-login-fallback{display:none}body:has(#root:not(:empty)) .static-login-fallback{display:none}button,input,select{font:inherit}.app-shell{grid-template-columns:256px 1fr;min-height:100vh;display:grid}.sidebar{color:#f9fafb;background:#111827;flex-direction:column;gap:24px;height:100vh;padding:20px 14px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;padding:4px 8px;display:flex}.brand span{color:#aeb6c7;margin-top:2px;font-size:12px;display:block}.sidebar nav{gap:4px;display:grid}.sidebar button{color:#cbd5e1;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.sidebar button:hover,.sidebar button.active{color:#fff;background:#ffffff1a}main{min-width:0;padding:22px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;display:flex}.topbar h1{letter-spacing:0;margin:0;font-size:24px}.topbar-title span{color:var(--muted);font-size:13px}.topbar-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.button,.icon-button{border:1px solid var(--accent);background:var(--accent);color:#fff;cursor:pointer;border-radius:8px;align-items:center;gap:8px;min-height:36px;padding:8px 12px;text-decoration:none;display:inline-flex}.button:hover{background:var(--accent-strong)}.button:disabled{opacity:.5;cursor:not-allowed}.button-secondary,.icon-button{color:var(--text);background:var(--surface);border-color:var(--border)}.button-secondary:hover,.icon-button:hover{background:var(--surface-2)}.icon-button{justify-content:center;width:38px;padding:0}.user-chip{background:var(--surface);border:1px solid var(--border);border-radius:999px;align-items:center;gap:8px;min-height:36px;padding:4px 10px 4px 4px;display:inline-flex}.user-chip img,.user-chip span{background:var(--accent);color:#fff;border-radius:50%;place-items:center;width:26px;height:26px;display:grid}.panel-stack{gap:16px;display:grid}.panel,.alert,.toolbar,.bulkbar{background:var(--surface);border:1px solid var(--border);border-radius:8px}.panel{padding:18px}.panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.panel-header h2{margin:0;font-size:18px}.panel-header p{color:var(--muted);margin:4px 0 0;font-size:14px}.alert{align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 14px;display:flex}.alert p{color:var(--muted);margin:2px 0 0}.alert.warning{background:#fff8ec;border-color:#ffd8a8}.alert.danger{background:#fff5f5;border-color:#ffc9c9}.alert.info{background:#eff6ff;border-color:#bfdbfe}.metric-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.metric{background:var(--surface);border:1px solid var(--border);border-radius:8px;gap:8px;padding:14px;display:grid}.metric span{color:var(--muted);font-size:13px}.metric strong{letter-spacing:0;font-size:20px}.badge{border:1px solid var(--border);min-height:24px;color:var(--muted);white-space:nowrap;background:#f8fafc;border-radius:999px;justify-content:center;align-items:center;padding:2px 9px;font-size:12px;display:inline-flex}.badge-success{color:var(--success);background:#ebfbee;border-color:#c3fae8}.badge-warning{color:var(--warning);background:#fff4e6;border-color:#ffe8cc}.badge-danger{color:var(--danger);background:#fff5f5;border-color:#ffc9c9}.badge-info{color:var(--info);background:#e7f5ff;border-color:#d0ebff}.check-grid,.flag-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.check-item,.flag{border:1px solid var(--border);background:#fbfcff;border-radius:8px;align-items:center;gap:10px;min-height:42px;padding:10px;display:flex}.flag{justify-content:space-between}.toolbar,.bulkbar{flex-wrap:wrap;align-items:center;gap:10px;padding:12px;display:flex}.bulkbar{z-index:5;position:sticky;top:0;box-shadow:0 8px 20px #0f172a14}.searchbox{border:1px solid var(--border);background:#fff;border-radius:8px;flex:1;align-items:center;gap:8px;min-width:240px;padding:0 10px;display:flex}.searchbox input,.bulkbar input,.bulkbar select{background:0 0;border:0;outline:0;min-width:160px;min-height:36px}.bulkbar input,.bulkbar select{border:1px solid var(--border);background:#fff;border-radius:8px;padding:0 10px}.table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:760px}th,td{border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;padding:11px 12px}th{color:var(--muted);text-transform:uppercase;background:#f8fafc;font-size:12px}td span{color:var(--muted);margin-top:2px;font-size:12px;display:block}code{background:#f1f5f9;border-radius:6px;padding:2px 5px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px}.empty-state{min-height:220px;color:var(--muted);text-align:center;align-content:center;place-items:center;gap:8px;display:grid}.empty-state h3{color:var(--text);margin:6px 0 0}.empty-state p{max-width:420px;margin:0}.swatch{vertical-align:middle;border:1px solid #00000026;border-radius:4px;width:14px;height:14px;margin-right:8px;display:inline-block}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-info{color:var(--info)}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=900px){.app-shell{grid-template-columns:1fr}.sidebar{height:auto;position:static}.sidebar nav{grid-template-columns:repeat(3,minmax(0,1fr))}.topbar{flex-direction:column;align-items:flex-start}.metric-strip,.check-grid,.flag-grid{grid-template-columns:1fr}main{padding:14px}}@media (width<=520px){.sidebar nav{grid-template-columns:repeat(2,minmax(0,1fr))}.sidebar button{font-size:13px}.panel-header{flex-direction:column}.toolbar,.bulkbar{align-items:stretch}.searchbox,.bulkbar input,.bulkbar select,.button{width:100%}}.login-cta{justify-content:center;padding:24px 0 8px;display:flex}.row-selected{background:#eef2ff}.role-chips{flex-wrap:wrap;gap:6px;display:flex}.chip{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:999px;align-items:center;gap:5px;padding:2px 9px;font-size:12px;display:inline-flex}.chip-muted{color:var(--muted)}.chip-removable button{cursor:pointer;color:var(--muted);background:0 0;border:0;padding:0 0 0 2px;font-size:14px;line-height:1}.chip-button{cursor:pointer}.role-chip{padding-left:8px}.chip-x{cursor:pointer;color:var(--muted);opacity:0;background:0 0;border:0;padding:0 0 0 4px;font-size:15px;line-height:1;transition:opacity .12s}.removable-hover:hover .chip-x{opacity:1}.removable-hover:hover{border-color:var(--danger);background:#fff5f5}.chip-x:hover{color:var(--danger);font-weight:700}.quick-add-select{border:1px solid var(--border);background:#fff;border-radius:8px;max-width:140px;min-height:32px;padding:0 8px;font-size:13px}.chip-button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.muted-inline{color:var(--muted);font-size:13px}.filter-box{flex:0 280px;min-width:200px}.filter-clear{cursor:pointer;color:var(--muted);background:0 0;border:0;padding:0 4px;font-size:16px}.filter-clear:hover{color:var(--danger)}.table-note{color:var(--muted);border-top:1px solid var(--border);padding:10px 12px;font-size:13px}.link-button{cursor:pointer;color:var(--text);background:0 0;border:0;align-items:center;gap:6px;padding:4px 0;font-weight:600;display:inline-flex}.link-button:hover{color:var(--accent)}.channel-layout{grid-template-columns:340px 1fr;align-items:start;gap:16px;display:grid}.channel-tree{gap:6px;max-height:70vh;display:grid;overflow-y:auto}.channel-cat{gap:2px;display:grid}.channel-cat-head{padding:6px 4px 2px}.channel-row{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:14px;display:flex}.channel-row:hover{background:var(--surface-2)}.channel-row span{color:var(--text)}.target-add{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.target-add select,.target-add input{border:1px solid var(--border);background:#fff;border-radius:8px;min-width:160px;min-height:36px;padding:0 10px}.perm-matrix{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:16px;display:grid}.perm-group h4{text-transform:uppercase;color:var(--muted);letter-spacing:.03em;margin:0 0 8px;font-size:13px}.perm-row{border:1px solid var(--border);cursor:pointer;text-align:left;background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;width:100%;margin-bottom:6px;padding:8px 10px;font-size:13px;display:flex}.perm-row:hover{border-color:var(--accent)}.perm-label{align-items:center;gap:6px;display:inline-flex}.perm-state{color:var(--muted);white-space:nowrap;font-size:12px;font-weight:600}.perm-allow{background:#ebfbee;border-color:#c3fae8}.perm-allow .perm-state{color:var(--success)}.perm-deny{background:#fff5f5;border-color:#ffc9c9}.perm-deny .perm-state{color:var(--danger)}.perm-neutral{background:#f1f8ff;border-color:#d0ebff}.perm-neutral .perm-state{color:var(--info)}.dot-danger{background:var(--danger);border-radius:50%;width:6px;height:6px;display:inline-block}.mode-switch{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;padding:10px;display:flex}.mode-btn{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;min-height:34px;padding:6px 14px;font-size:13px;font-weight:600}.mode-btn:hover{border-color:var(--accent)}.mode-allow{border-color:var(--success);color:var(--success);background:#ebfbee}.mode-deny{border-color:var(--danger);color:var(--danger);background:#fff5f5}.mode-neutral{border-color:var(--info);color:var(--info);background:#f1f8ff}.perm-summary{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.perm-group-head{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.perm-group-head h4{margin:0}.group-quick{gap:2px;display:inline-flex}.group-quick button{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:6px;width:24px;height:24px;font-size:12px;line-height:1}.group-quick button:hover{border-color:var(--accent)}.perm-tri{border:1px solid var(--border);background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px;padding:7px 10px;font-size:13px;display:flex}.perm-tri.perm-allow{background:#f4fffa;border-color:#c3fae8}.perm-tri.perm-deny{background:snow;border-color:#ffc9c9}.perm-tri.perm-neutral{background:#f7fbff;border-color:#d0ebff}.tri-seg{border:1px solid var(--border);border-radius:7px;flex-shrink:0;display:inline-flex;overflow:hidden}.tri-seg button{cursor:pointer;width:30px;height:28px;color:var(--muted);border:0;border-left:1px solid var(--border);background:#fff;font-size:13px}.tri-seg button:first-child{border-left:0}.tri-seg button.on.allow{background:var(--success);color:#fff}.tri-seg button.on.deny{background:var(--danger);color:#fff}.tri-seg button.on.neutral{background:var(--info);color:#fff}.tri-seg button:hover:not(.on){background:var(--surface-2)}.apply-bar{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding-top:14px;display:flex}.apply-bar input{border:1px solid var(--border);background:#fff;border-radius:8px;flex:1;min-width:200px;min-height:38px;padding:0 12px}.quick-roles{flex-wrap:wrap;align-items:center;gap:6px;margin-top:12px;display:flex}.toolbar select{border:1px solid var(--border);background:#fff;border-radius:8px;min-height:36px;padding:0 10px}.bulkbar select{min-width:150px}.channel-name{cursor:pointer;flex:1}.inspect-btn{cursor:pointer;color:var(--muted);background:0 0;border:0;border-radius:6px;padding:4px;display:inline-flex}.inspect-btn:hover{background:var(--surface-2);color:var(--accent)}.modal-overlay{z-index:100;background:#0f172a73;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;width:min(820px,100%);max-height:88vh;display:flex;box-shadow:0 24px 60px #0f172a40}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px;display:flex}.modal-head h3{align-items:center;gap:8px;margin:0;font-size:17px;display:inline-flex}.modal-head p{margin:4px 0 0}.modal-body{padding:18px 20px;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);align-items:center;gap:8px;padding:14px 20px;display:flex}.modal-foot input{border:1px solid var(--border);background:#fff;border-radius:8px;flex:1;min-height:38px;padding:0 12px}.perm-off .perm-state{color:var(--muted)}.modal-sm{width:min(480px,100%)}.modal-wide{width:min(1000px,100%)}.access-section{margin-bottom:20px}.access-section>h4{margin:0 0 10px;font-size:14px}.access-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.access-head h4{margin:0;font-size:14px}.access-list{gap:8px;max-height:56vh;display:grid;overflow-y:auto}.access-row{border:1px solid var(--border);border-radius:10px;padding:10px 12px}.access-row.access-hidden{opacity:.6;background:#fafbfc}.access-main{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.access-name{flex:0 auto;font-weight:600}.access-edit{margin-left:auto}.access-detail{gap:6px;margin-top:8px;padding-left:22px;display:grid}.access-ow{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.ow-tag{color:var(--muted);text-transform:uppercase;min-width:86px;font-size:11px;font-weight:700}.multi-role{position:relative}.multi-role-btn{border:1px solid var(--border);cursor:pointer;text-align:left;background:#fff;border-radius:8px;min-width:170px;min-height:36px;padding:0 12px}.multi-role-pop{z-index:30;border:1px solid var(--border);background:#fff;border-radius:10px;width:280px;padding:8px;position:absolute;top:calc(100% + 4px);left:0;box-shadow:0 14px 40px #0f172a2e}.multi-role-search{border:1px solid var(--border);border-radius:8px;width:100%;min-height:34px;margin-bottom:6px;padding:0 10px}.multi-role-list{gap:2px;max-height:240px;display:grid;overflow-y:auto}.multi-role-item{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:14px;display:flex}.multi-role-item:hover{background:var(--surface-2)}.multi-role-foot{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;margin-top:6px;padding-top:8px;display:flex}.modal-wide .channel-tree{max-height:52vh}.modal-wide .perm-matrix{grid-template-columns:1fr}.modal-tabs{border-bottom:1px solid var(--border);gap:4px;padding:0 20px;display:flex}.modal-tabs button{cursor:pointer;color:var(--muted);background:0 0;border:0;border-bottom:2px solid #0000;padding:12px 14px;font-weight:600}.modal-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.field{margin-bottom:16px}.field label{color:var(--muted);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.field input{border:1px solid var(--border);background:#fff;border-radius:8px;width:100%;min-height:38px;padding:0 12px}.color-grid{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.color-dot{cursor:pointer;border:2px solid #0000;border-radius:8px;width:28px;height:28px}.color-dot.active{border-color:var(--text);box-shadow:inset 0 0 0 2px #fff}.color-grid input[type=color]{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;width:38px;height:32px;padding:2px}.toggle-row{flex-wrap:wrap;gap:20px;display:flex}.toggle{cursor:pointer;align-items:center;gap:8px;font-size:14px;display:inline-flex}.row-actions{justify-content:flex-end;align-items:center;gap:6px;display:inline-flex}.row-actions .icon-button{width:32px;min-height:32px}.danger-btn{color:var(--danger);border-color:#ffc9c9}.danger-btn:hover{background:#fff5f5}.danger-solid{background:var(--danger);border-color:var(--danger)}.danger-solid:hover{background:#a51111}.overwrite-list{gap:10px;display:grid}.overwrite-card{border:1px solid var(--border);border-radius:10px;padding:12px}.overwrite-head{align-items:center;gap:8px;margin-bottom:8px;display:flex}.overwrite-perms{flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;display:flex}.ow-allow{color:var(--success);text-transform:uppercase;font-size:11px;font-weight:700}.ow-deny{color:var(--danger);text-transform:uppercase;font-size:11px;font-weight:700}.chip-allow{color:var(--success);background:#ebfbee;border-color:#c3fae8}.chip-deny{color:var(--danger);background:#fff5f5;border-color:#ffc9c9}@media (width<=1100px){.channel-layout,.perm-matrix{grid-template-columns:1fr}}
