html,body{width:100%;height:100%}input::-ms-clear,input::-ms-reveal{display:none}*,*:before,*:after{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-ms-overflow-style:scrollbar;-webkit-tap-highlight-color:rgba(0,0,0,0)}@-ms-viewport{width:device-width}body{margin:0}[tabindex="-1"]:focus{outline:none}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5em;font-weight:500}p{margin-top:0;margin-bottom:1em}abbr[title],abbr[data-original-title]{-webkit-text-decoration:underline dotted;text-decoration:underline;text-decoration:underline dotted;border-bottom:0;cursor:help}address{margin-bottom:1em;font-style:normal;line-height:inherit}input[type=text],input[type=password],input[type=number],textarea{-webkit-appearance:none}ol,ul,dl{margin-top:0;margin-bottom:1em}ol ol,ul ul,ol ul,ul ol{margin-bottom:0}dt{font-weight:500}dd{margin-bottom:.5em;margin-left:0}blockquote{margin:0 0 1em}dfn{font-style:italic}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}pre,code,kbd,samp{font-size:1em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace}pre{margin-top:0;margin-bottom:1em;overflow:auto}figure{margin:0 0 1em}img{vertical-align:middle;border-style:none}a,area,button,[role=button],input:not([type=range]),label,select,summary,textarea{touch-action:manipulation}table{border-collapse:collapse}caption{padding-top:.75em;padding-bottom:.3em;text-align:left;caption-side:bottom}input,button,select,optgroup,textarea{margin:0;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}button,html [type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{padding:0;border-style:none}input[type=radio],input[type=checkbox]{box-sizing:border-box;padding:0}input[type=date],input[type=time],input[type=datetime-local],input[type=month]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;margin:0;padding:0;border:0}legend{display:block;width:100%;max-width:100%;margin-bottom:.5em;padding:0;color:inherit;font-size:1.5em;line-height:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item}template{display:none}[hidden]{display:none!important}mark{padding:.2em;background-color:#feffe6}.mockup-shell{--bg: #eef1f5;--surface: #ffffff;--ink: #0e1116;--ink-2: #2b313a;--ink-3: #5a626d;--ink-4: #8a92a0;--rule: #d9dee6;--rule-2: #e6eaf0;--accent: #2253c6;--accent-bg: #e4ebfa;--teal: #156b7a;--teal-bg: #dceaee;--amber: #8a5a10;--amber-bg: #f0e4cc;--red: #b02a2a;--red-bg: #f3dcdc;--green: #245c3e;--green-bg: #d8e8de;--violet: #5a33a8;--violet-bg: #e6def5;--sans: "Geist", ui-sans-serif, system-ui, sans-serif;--mono: "Geist Mono", ui-monospace, monospace;--r: 6px;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:14px;min-height:100vh;-webkit-font-smoothing:antialiased}.mockup-shell,.mockup-shell *{box-sizing:border-box}.mockup-shell .topnav{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:4px;background:var(--surface);border-bottom:1px solid var(--rule);padding:0 16px;height:44px}.mockup-shell .topnav .brand{display:inline-flex;align-items:center;gap:8px;margin-right:12px;text-decoration:none;color:inherit}.mockup-shell .topnav .brand .dot{width:12px;height:12px;border-radius:3px;background:var(--ink)}.mockup-shell .topnav .brand .name{font-weight:600;font-size:13px;letter-spacing:-.01em}.mockup-shell .topnav .navgrp{display:inline-flex;align-items:center;gap:2px}.mockup-shell .topnav .sep{width:1px;height:18px;background:var(--rule);margin:0 8px}.mockup-shell .topnav a.link{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;border-radius:5px;text-decoration:none;color:var(--ink-3);font-size:13px;font-weight:500;line-height:1}.mockup-shell .topnav a.link:hover{background:var(--rule-2);color:var(--ink)}.mockup-shell .topnav a.link.on{color:var(--ink);background:var(--rule-2)}.mockup-shell .topnav a.link .pill{font-family:var(--mono);font-size:10px;padding:1px 5px;border-radius:99px;background:var(--rule-2);color:var(--ink-3)}.mockup-shell .topnav a.link.on .pill{background:var(--ink);color:var(--surface)}.mockup-shell .topnav a.link .pill.red{background:var(--red);color:var(--surface)}.mockup-shell .topnav .spacer{flex:1}.mockup-shell .topnav .cmd{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--rule);border-radius:5px;padding:5px 10px;color:var(--ink-3);font-size:12px;min-width:240px;cursor:text}.mockup-shell .topnav .cmd:hover{border-color:var(--ink-3);background:var(--surface)}.mockup-shell .topnav .cmd .kbd{margin-left:auto;font-family:var(--mono);font-size:10px;padding:1px 5px;border:1px solid var(--rule);border-radius:3px;color:var(--ink-3)}.mockup-shell .topnav .user{display:inline-flex;align-items:center;gap:8px;padding:3px 6px 3px 3px;border-radius:99px;cursor:pointer;margin-left:8px}.mockup-shell .topnav .user:hover{background:var(--rule-2)}.mockup-shell .topnav .user .ava{width:26px;height:26px;border-radius:50%;background:var(--accent);color:var(--surface);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.mockup-shell .topnav .user .nm{font-size:12px;color:var(--ink-2)}.mockup-shell .subnav{position:sticky;top:44px;z-index:19;display:flex;align-items:center;gap:10px;background:var(--surface);border-bottom:1px solid var(--rule);padding:8px 16px;font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em}.mockup-shell .subnav .crumb{color:var(--ink-2);cursor:pointer;text-decoration:none}.mockup-shell .subnav .crumb:hover{color:var(--accent)}.mockup-shell .subnav .sl{opacity:.4}.mockup-shell .subnav .scope-pick{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;background:var(--bg);border:1px solid var(--rule);border-radius:4px;cursor:pointer;color:var(--ink-2)}.mockup-shell .subnav .scope-pick:hover{border-color:var(--ink-3)}.mockup-shell .subnav .scope-pick .sw{width:7px;height:7px;border-radius:2px;background:var(--accent)}.mockup-shell .subnav .sright{margin-left:auto;display:inline-flex;gap:14px;align-items:center}@media (max-width: 820px){.mockup-shell .topnav{overflow-x:auto;padding:0 10px}.mockup-shell .topnav .cmd,.mockup-shell .topnav .user .nm{display:none}.mockup-shell .subnav{overflow-x:auto;white-space:nowrap}}.mockup-shell .page{padding:20px 28px 120px;min-width:0}.mockup-shell .page h1{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em}.mockup-shell .page h1 .muted{color:var(--ink-3);font-weight:400}.mockup-shell .page .sub{color:var(--ink-3);font-size:12px;margin:4px 0 16px;font-family:var(--mono);letter-spacing:.02em}.mockup-shell .page .topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px}.mockup-shell .page .topbar .tools{display:flex;gap:6px;align-items:center;flex-shrink:0}@media (max-width: 820px){.mockup-shell .page{padding:14px 12px 120px}}.mockup-shell .page-split{display:grid;grid-template-columns:240px 1fr;align-items:start;min-height:calc(100vh - 82px)}.mockup-shell .page-split .localrail{border-right:1px solid var(--rule);background:var(--surface);padding:18px 14px;position:sticky;top:82px;align-self:start;max-height:calc(100vh - 82px);overflow-y:auto}.mockup-shell .page-split .localrail .search{width:100%;border:1px solid var(--rule);border-radius:5px;padding:8px 10px;font:400 13px/1.2 var(--sans);outline:0;background:var(--bg);margin-bottom:14px}.mockup-shell .page-split .localrail .search:focus{border-color:var(--ink-3);background:var(--surface)}.mockup-shell .page-split .localrail .railsec{margin-bottom:16px}.mockup-shell .page-split .localrail .railsec .t{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);padding:0 8px 6px;display:flex;justify-content:space-between}.mockup-shell .page-split .localrail .rnav{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:13px;color:var(--ink-2);line-height:1.2}.mockup-shell .page-split .localrail .rnav:hover{background:var(--rule-2)}.mockup-shell .page-split .localrail .rnav.on{background:var(--accent-bg);color:var(--accent);font-weight:500}.mockup-shell .page-split .localrail .rnav .l{display:inline-flex;align-items:center;gap:8px}.mockup-shell .page-split .localrail .rnav .ic{width:14px;font-family:var(--mono);font-size:11px;color:var(--ink-3);text-align:center}.mockup-shell .page-split .localrail .rnav.on .ic{color:var(--accent)}.mockup-shell .page-split .localrail .rnav .n{font-family:var(--mono);font-size:10px;color:var(--ink-3)}.mockup-shell .page-split .localrail .rnav.on .n{color:var(--accent)}.mockup-shell .page-split .localrail .rnav .n.red{color:var(--red);font-weight:600}.mockup-shell .page-split>.page{min-width:0}@media (max-width: 900px){.mockup-shell .page-split{grid-template-columns:1fr}.mockup-shell .page-split .localrail{display:none}}.mockup-shell .strip{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}@media (max-width: 820px){.mockup-shell .strip{grid-template-columns:repeat(2,1fr)}}.mockup-shell .strip .k{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r);padding:12px 14px;cursor:pointer;position:relative}.mockup-shell .strip .k:hover{border-color:var(--ink-3)}.mockup-shell .strip .k.on{border-color:var(--ink);box-shadow:inset 0 -2px 0 var(--ink)}.mockup-shell .strip .k .label{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}.mockup-shell .strip .k .num{font-size:22px;font-weight:600;letter-spacing:-.02em;margin-top:4px;line-height:1}.mockup-shell .strip .k .num .ow{color:var(--red)}.mockup-shell .strip .k .delta{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:6px}.mockup-shell .strip .k .delta .warn{color:var(--amber)}.mockup-shell .strip .k .delta .bad,.mockup-shell .strip .k .delta .up{color:var(--red)}.mockup-shell .strip .k .delta .dn{color:var(--green)}.mockup-shell .strip .k .pulse{position:absolute;top:12px;right:12px;width:7px;height:7px;border-radius:50%;background:var(--red)}.mockup-shell .inbox-item{display:grid;grid-template-columns:4px 24px 1.6fr 1.2fr 120px 28px;gap:10px;padding:11px 14px;border-bottom:1px solid var(--rule);align-items:center;cursor:pointer}.mockup-shell .inbox-item:last-child{border-bottom:0}.mockup-shell .inbox-item:hover{background:var(--rule-2)}.mockup-shell .inbox-item.unread{background:#fbfcfd}.mockup-shell .inbox-item.unread .title{font-weight:600}.mockup-shell .inbox-item .urg{width:4px;height:30px;border-radius:2px;background:var(--rule)}.mockup-shell .inbox-item.hot .urg{background:var(--red)}.mockup-shell .inbox-item.warm .urg{background:var(--amber)}.mockup-shell .inbox-item.cool .urg{background:var(--ink-4)}.mockup-shell .inbox-item.done .urg{background:var(--green)}.mockup-shell .inbox-item .kind{width:24px;height:24px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600;font-size:9px;background:var(--rule-2);color:var(--ink-2)}.mockup-shell .inbox-item .kind.ans{background:var(--accent-bg);color:var(--accent)}.mockup-shell .inbox-item .kind.apr{background:var(--teal-bg);color:var(--teal)}.mockup-shell .inbox-item .kind.men{background:var(--amber-bg);color:var(--amber)}.mockup-shell .inbox-item .kind.wat{background:var(--rule-2);color:var(--ink-3)}.mockup-shell .inbox-item .kind.upd{background:var(--green-bg);color:var(--green)}.mockup-shell .inbox-item .title{font-weight:500;font-size:14px;line-height:1.3;color:var(--ink)}.mockup-shell .inbox-item .title .tag{display:inline-block;font-family:var(--mono);font-size:10px;padding:1px 5px;border-radius:3px;background:var(--rule-2);color:var(--ink-3);margin-right:4px}.mockup-shell .inbox-item .title .crumbs{display:block;font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.04em;margin-top:3px;font-weight:400}.mockup-shell .inbox-item .title .crumbs .sl{opacity:.5}.mockup-shell .inbox-item .who{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2)}.mockup-shell .inbox-item .who .ava{width:22px;height:22px;border-radius:50%;background:var(--ink);color:var(--surface);display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;flex-shrink:0}.mockup-shell .inbox-item .who .verb{color:var(--ink-3)}.mockup-shell .inbox-item .when{font-family:var(--mono);font-size:11px;color:var(--ink-2);text-align:right}.mockup-shell .inbox-item.hot .when{color:var(--red);font-weight:600}.mockup-shell .inbox-item.warm .when{color:var(--amber)}.mockup-shell .inbox-item .when .rel{display:block;font-size:10px;color:var(--ink-3);font-weight:400;margin-top:2px}.mockup-shell .inbox-item .chev{color:var(--ink-3);font-family:var(--mono);font-size:14px;justify-self:end}.mockup-shell .group-head{display:flex;align-items:center;justify-content:space-between;padding:6px 2px 8px}.mockup-shell .group-head .gt{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}.mockup-shell .group-head .gt .bar{width:3px;height:12px;border-radius:2px;background:var(--ink-4)}.mockup-shell .group-head.overdue .bar{background:var(--red)}.mockup-shell .group-head.today .bar{background:var(--amber)}.mockup-shell .group-head.week .bar{background:var(--accent)}.mockup-shell .group-head.later .bar{background:var(--ink-4)}.mockup-shell .group-head .gt .n{background:var(--rule-2);padding:1px 6px;border-radius:99px;color:var(--ink-2);font-size:10px}.mockup-shell .group-head.overdue .n{background:var(--red-bg);color:var(--red)}.mockup-shell .group-head .act{font-family:var(--mono);font-size:10px;color:var(--accent);cursor:pointer}.mockup-shell .list-box{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r);overflow:hidden}.mockup-shell .src-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.mockup-shell .src{background:var(--surface);border:1px solid var(--rule);border-radius:var(--r);padding:14px;display:flex;flex-direction:column;gap:10px;cursor:pointer;position:relative;min-height:200px}.mockup-shell .src:hover{border-color:var(--ink-3);box-shadow:0 1px 0 var(--rule-2)}.mockup-shell .src .row1{display:flex;align-items:flex-start;gap:10px}.mockup-shell .src .ftype{width:36px;height:44px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600;font-size:10px;flex-shrink:0;position:relative;background:var(--rule-2);color:var(--ink-2)}.mockup-shell .src .ftype.pdf{background:#f7e2dc;color:#7a2f1a}.mockup-shell .src .ftype.dwg{background:#dce9f7;color:#1a467a}.mockup-shell .src .ftype.xls{background:#dcf0e2;color:#1a5a36}.mockup-shell .src .ftype.doc{background:#e4e0f2;color:#3a2a7a}.mockup-shell .src .ftype.img{background:#f2eadc;color:#6e501a}.mockup-shell .src .ftype:after{content:"";position:absolute;top:0;right:0;width:10px;height:10px;background:var(--surface);border-left:1px solid var(--rule);border-bottom:1px solid var(--rule);border-bottom-left-radius:2px}.mockup-shell .src .meta{min-width:0;flex:1}.mockup-shell .src .cite{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase;margin-bottom:2px}.mockup-shell .src .title{font-weight:600;font-size:14px;line-height:1.3;color:var(--ink)}.mockup-shell .src .publisher{font-size:12px;color:var(--ink-3);margin-top:3px}.mockup-shell .src .scope-pill{position:absolute;top:12px;right:12px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:3px;background:var(--violet-bg);color:var(--violet)}.mockup-shell .src .scope-pill.proj{background:var(--accent-bg);color:var(--accent)}.mockup-shell .src .scope-pill.firm{background:var(--teal-bg);color:var(--teal)}.mockup-shell .src .scope-pill.private{background:var(--rule-2);color:var(--ink-2)}.mockup-shell .src .descr{font-size:12px;color:var(--ink-3);line-height:1.45}.mockup-shell .src .tags{display:flex;flex-wrap:wrap;gap:4px}.mockup-shell .src .tag{font-family:var(--mono);font-size:10px;padding:2px 6px;background:var(--rule-2);color:var(--ink-3);border-radius:3px}.mockup-shell .src .foot{margin-top:auto;padding-top:8px;border-top:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;gap:8px;font-family:var(--mono);font-size:10px;color:var(--ink-3)}.mockup-shell .src .foot .l{display:inline-flex;gap:10px;align-items:center}.mockup-shell .src .used{color:var(--ink-2)}.mockup-shell .src .used b{color:var(--accent);font-weight:600}.mockup-shell .src .state{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10px;padding:2px 6px;border-radius:3px;letter-spacing:.04em}.mockup-shell .src .state.verified{background:var(--green-bg);color:var(--green)}.mockup-shell .src .state.review{background:var(--amber-bg);color:var(--amber)}.mockup-shell .src .state.superseded{background:var(--rule-2);color:var(--ink-3)}.mockup-shell .src .state.draft{background:var(--rule-2);color:var(--ink-3);border:1px dashed var(--rule)}.mockup-shell .src .state .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.mockup-shell .src .v{font-family:var(--mono);font-size:10px;color:var(--ink-3);padding:1px 5px;border:1px solid var(--rule);border-radius:3px}.mockup-shell .src.draft-bg{background:repeating-linear-gradient(-45deg,var(--surface),var(--surface) 8px,var(--rule-2) 8px,var(--rule-2) 10px)}.mockup-shell .src.supers{opacity:.72}.mockup-shell .src.supers .title{text-decoration:line-through;text-decoration-color:var(--ink-4)}.mockup-shell .sec-head{display:flex;align-items:center;justify-content:space-between;margin:6px 0 10px}.mockup-shell .sec-head .t{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}.mockup-shell .sec-head .t .bar{width:3px;height:14px;border-radius:2px;background:var(--violet)}.mockup-shell .sec-head .t .bar.amber{background:var(--amber)}.mockup-shell .sec-head .t .bar.teal{background:var(--teal)}.mockup-shell .sec-head .t .bar.ink{background:var(--ink-4)}.mockup-shell .sec-head .t .n{background:var(--rule-2);padding:1px 6px;border-radius:99px;color:var(--ink-2);font-size:10px}.mockup-shell .sec-head .act{font-family:var(--mono);font-size:10px;color:var(--accent);cursor:pointer}.mockup-shell .acl-scope-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}.mockup-shell .acl-scope{border:1px solid var(--rule);border-radius:5px;padding:10px 12px;cursor:pointer;position:relative}.mockup-shell .acl-scope:hover{border-color:var(--ink-3)}.mockup-shell .acl-scope.on{border-color:var(--ink);background:var(--rule-2)}.mockup-shell .acl-scope .t1{font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:6px}.mockup-shell .acl-scope .t1 .sw{width:8px;height:8px;border-radius:2px;background:var(--ink-4)}.mockup-shell .acl-scope .t1 .sw.global{background:var(--violet)}.mockup-shell .acl-scope .t1 .sw.firm{background:var(--teal)}.mockup-shell .acl-scope .t1 .sw.project{background:var(--accent)}.mockup-shell .acl-scope .t1 .sw.private{background:var(--ink)}.mockup-shell .acl-scope .h{font-size:11px;color:var(--ink-3);line-height:1.35;margin-top:2px}.mockup-shell .acl-scope.on:after{content:"✓";position:absolute;top:8px;right:10px;font-size:11px;font-family:var(--mono);color:var(--ink)}.mockup-shell .acl-sec{margin-bottom:18px}.mockup-shell .acl-sec .lbl{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}.mockup-shell .acl-sec .lbl .help{color:var(--ink-4);font-size:10px;letter-spacing:.04em;text-transform:none}.mockup-shell .acl-conflict{padding:10px 12px;border-radius:5px;background:var(--amber-bg);border:1px solid #e6ce8a;color:var(--amber);font-size:12px;line-height:1.45;margin-bottom:14px}.mockup-shell .acl-conflict b{color:var(--ink)}.mockup-shell .acl-role-row{display:grid;grid-template-columns:28px 1fr auto;gap:10px;padding:10px 12px;align-items:center;border-bottom:1px solid var(--rule)}.mockup-shell .acl-role-row:last-child{border-bottom:0}.mockup-shell .acl-role-row .ava{width:24px;height:24px;border-radius:50%;background:var(--ink);color:var(--surface);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600}.mockup-shell .acl-role-row .ava.team{border-radius:4px;background:var(--rule-2);color:var(--ink-2);font-family:var(--mono);font-size:9px}.mockup-shell .acl-role-row .ava.accent{background:var(--accent)}.mockup-shell .acl-role-row .ava.teal{background:var(--teal)}.mockup-shell .acl-role-row .ava.amber{background:var(--amber)}.mockup-shell .acl-role-row .ava.violet{background:var(--violet)}.mockup-shell .acl-role-row .ava.green{background:var(--green)}.mockup-shell .acl-role-row .ava.neutral{background:var(--rule-2);color:var(--ink-2)}.mockup-shell .acl-role-row .nm{font-size:13px;color:var(--ink);line-height:1.2}.mockup-shell .acl-role-row .sub{font-size:11px;color:var(--ink-3);font-family:var(--mono);margin-top:1px}.mockup-shell .acl-role-add{display:flex;align-items:center;gap:8px;padding:9px 12px;color:var(--accent);cursor:pointer;font-size:12px;font-family:var(--mono);border-top:1px dashed var(--rule)}.mockup-shell .acl-role-add:hover{background:var(--accent-bg)}.mockup-shell .acl-toggle-row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--rule-2);gap:14px}.mockup-shell .acl-toggle-row:last-child{border-bottom:0}.mockup-shell .acl-toggle-row .lt{font-size:13px;color:var(--ink);font-weight:500}.mockup-shell .acl-toggle-row .ls{font-size:11px;color:var(--ink-3);margin-top:2px;line-height:1.4;font-family:var(--mono);letter-spacing:.02em}.mockup-shell .acl-prov{background:var(--bg);border:1px solid var(--rule);border-radius:5px;padding:10px 12px;font-size:12px;color:var(--ink-2);line-height:1.55}.mockup-shell .acl-prov .row{display:flex;justify-content:space-between;gap:12px;padding:3px 0}.mockup-shell .acl-prov .row .k{color:var(--ink-3);font-family:var(--mono);font-size:11px}.mockup-shell .acl-prov .row .v{color:var(--ink-2);font-size:12px;text-align:right}.mockup-shell .acl-audit{display:flex;flex-direction:column;gap:10px}.mockup-shell .acl-audit .ev{display:grid;grid-template-columns:12px 1fr auto;gap:10px;align-items:start}.mockup-shell .acl-audit .ev .d{width:6px;height:6px;border-radius:50%;background:var(--ink-4);margin-top:6px}.mockup-shell .acl-audit .ev.ok .d{background:var(--green)}.mockup-shell .acl-audit .ev.warn .d{background:var(--amber)}.mockup-shell .acl-audit .ev .tx{font-size:12px;color:var(--ink-2);line-height:1.4}.mockup-shell .acl-audit .ev .tx b{color:var(--ink);font-weight:600}.mockup-shell .acl-audit .ev .when{font-family:var(--mono);font-size:10px;color:var(--ink-3);white-space:nowrap}.mockup-shell .acl-foot{display:flex;justify-content:space-between;align-items:center;gap:10px}.mockup-shell .acl-foot .l{font-family:var(--mono);font-size:11px;color:var(--ink-3)}.mockup-shell .acl-foot .l b{color:var(--amber);font-weight:600}.mockup-shell .wip{padding:40px;border:1.5px dashed var(--rule);background:var(--surface);border-radius:var(--r);text-align:center;color:var(--ink-3);font-size:13px}.mockup-shell .wip strong{color:var(--ink);font-weight:600;display:block;margin-bottom:6px;font-size:16px}.mockup-shell .wip code{font-family:var(--mono);font-size:11px;background:var(--rule-2);padding:2px 6px;border-radius:3px;color:var(--ink-2)}:root{--color-primary-50: #e8faf1;--color-primary-100: #b5f0d5;--color-primary-200: #7de4b5;--color-primary-300: #5edda5;--color-primary-400: #2ecc87;--color-primary-500: #1fa56b;--color-primary-600: #157a4f;--color-primary-700: #0d5437;--color-primary-800: #082e1f;--color-primary-900: #041710;--color-primary: var(--color-primary-400);--color-primary-light: var(--color-primary-300);--color-primary-dark: var(--color-primary-500);--color-primary-subtle: rgba(46, 204, 135, .08);--color-primary-muted: rgba(46, 204, 135, .15);--color-base-50: #e3f2f3;--color-base-100: #b8dcde;--color-base-200: #85c4c7;--color-base-300: #4da8ac;--color-base-400: #2a8a8f;--color-base-500: #1e6e73;--color-base-600: #17595e;--color-base-700: #124a4e;--color-base-800: #0d3b3e;--color-base-900: #081e20;--color-neutral-50: #f2f4f6;--color-neutral-100: #dee2e7;--color-neutral-200: #bcc3cc;--color-neutral-300: #9aa4b2;--color-neutral-400: #7a8696;--color-neutral-500: #5a6577;--color-neutral-600: #3d4758;--color-neutral-700: #2a3240;--color-neutral-800: #1a2028;--color-neutral-900: #0f1419;--color-success: #2ecc87;--color-warning: #f5a623;--color-error: #e74c5e;--color-info: #4a9ef5;--color-chart-1: #2ecc87;--color-chart-2: #4a9ef5;--color-chart-3: #f5a623;--color-chart-4: #e74c5e;--color-chart-5: #a78bfa;--color-chart-6: #f472b6;--surface-background: var(--color-base-900);--surface-primary: var(--color-base-800);--surface-elevated: #114244;--surface-card: rgba(255, 255, 255, .04);--surface-card-hover: rgba(255, 255, 255, .07);--surface-overlay: rgba(8, 30, 32, .85);--text-primary: #ffffff;--text-secondary: #85b0ad;--text-tertiary: #5a8a87;--text-disabled: #3d6563;--text-inverse: #081e20;--text-link: var(--color-primary);--text-link-hover: var(--color-primary-light);--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .18);--border-focus: var(--color-primary);--border-error: var(--color-error);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 32px;--font-size-display: 48px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--font-weight-black: 900;--line-height-tight: 1.1;--line-height-snug: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.7;--letter-spacing-tight: -1.5px;--letter-spacing-snug: -1px;--letter-spacing-normal: 0;--letter-spacing-wide: 2.5px;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 24px rgba(46, 204, 135, .15);--ease-default: cubic-bezier(.25, .1, .25, 1);--ease-in-out: cubic-bezier(.42, 0, .58, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-instant: 75ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--duration-emphasis: .6s;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--container-full: 1440px;--grid-columns: 12;--grid-gutter-sm: 16px;--grid-gutter-md: 24px;--grid-gutter-lg: 32px;--column-gap-sm: 8px;--column-gap-md: 12px;--column-gap-lg: 16px;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--z-tooltip: 600;--focus-ring: 2px solid var(--color-primary);--focus-offset: 2px}.text-display{font-size:var(--font-size-display);font-weight:var(--font-weight-black);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight)}.text-h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);letter-spacing:var(--letter-spacing-snug);line-height:var(--line-height-snug)}.text-h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:-.5px;line-height:var(--line-height-snug)}.text-h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);line-height:var(--line-height-snug)}.text-body{font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal)}.text-caption{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:var(--line-height-normal)}.text-overline{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--surface-background: #f4f8f6;--surface-primary: #ffffff;--surface-elevated: #ffffff;--surface-card: rgba(8, 30, 32, .03);--surface-card-hover: rgba(8, 30, 32, .06);--surface-overlay: rgba(8, 30, 32, .45);--text-primary: #0d3b3e;--text-secondary: #5a8a87;--text-tertiary: #7ea5a2;--text-disabled: #a7c3c0;--text-inverse: #ffffff;--border-subtle: rgba(13, 59, 62, .08);--border-default: rgba(13, 59, 62, .14);--border-strong: rgba(13, 59, 62, .22);--color-bg: var(--surface-background);--color-surface: var(--surface-primary);--color-border: var(--border-default);--color-text: var(--text-primary);--color-text-dim: var(--text-secondary);--color-danger: var(--color-error);--tap-min: 44px;font-family:var(--font-family);line-height:var(--line-height-normal);color-scheme:light;color:var(--text-primary);background-color:var(--surface-background)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;-webkit-tap-highlight-color:transparent;background:var(--surface-background);color:var(--text-primary);font-family:var(--font-family)}button{font-family:inherit;font-size:1rem;padding:.75rem 1.1rem;min-height:var(--tap-min);border-radius:var(--radius-sm);border:1px solid var(--border-default);background:var(--surface-card);color:var(--text-primary);cursor:pointer;transition:background var(--duration-fast) var(--ease-default),border-color var(--duration-fast) var(--ease-default)}button:hover:not(:disabled){background:var(--surface-card-hover);border-color:var(--border-strong)}button:disabled{opacity:.5;cursor:not-allowed}button.primary,button[type=submit]{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-glow)}button.primary:hover:not(:disabled),button[type=submit]:hover:not(:disabled){background:var(--color-primary-300);border-color:var(--color-primary-300)}button.danger{background:var(--color-error);color:#fff;border-color:var(--color-error)}input,textarea,select{font-family:inherit;font-size:1rem;padding:.6rem .75rem;min-height:var(--tap-min);border:1px solid var(--border-default);border-radius:var(--radius-sm);width:100%;background:var(--surface-primary);color:var(--text-primary)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 2px var(--color-primary-muted)}textarea{resize:vertical;min-height:6rem;line-height:1.4}a{color:var(--text-link);text-decoration:none}a:hover{color:var(--text-link-hover);text-decoration:underline}.page{max-width:640px;margin:0 auto;padding:1rem 1rem 6rem}.page-header{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem;min-height:var(--tap-min)}.page-header h1{margin:0;font-size:1.25rem;flex:1;color:var(--text-primary)}.stack{display:grid;gap:.75rem}.card{background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1rem;box-shadow:var(--shadow-sm)}.muted{color:var(--text-secondary);font-size:.875rem}.fab{position:fixed;right:1.25rem;bottom:1.25rem;width:56px;height:56px;border-radius:28px;background:var(--color-primary);color:var(--text-inverse);font-size:1.5rem;border:none;box-shadow:var(--shadow-lg),var(--shadow-glow);z-index:var(--z-sticky);min-height:56px}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);z-index:var(--z-overlay);animation:fade-in .15s ease-out}.drawer{position:fixed;left:0;right:0;bottom:0;max-height:85vh;background:var(--surface-primary);border-top:1px solid var(--border-subtle);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:1.25rem;padding-bottom:env(safe-area-inset-bottom,1.25rem);z-index:var(--z-modal);overflow-y:auto;animation:slide-up .2s ease-out}.drawer h2{margin:0 0 1rem;font-size:1.1rem;color:var(--text-primary)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:var(--font-weight-semibold);color:#fff;text-transform:uppercase;letter-spacing:.02em}.badge.overdue{background:#991b1b}.badge.critical{background:var(--color-error)}.badge.high{background:var(--color-warning);color:var(--text-inverse)}.badge.medium{background:#eab308;color:var(--text-inverse)}.badge.low{background:var(--color-primary);color:var(--text-inverse)}.dropzone{border:2px dashed var(--border-default);border-radius:var(--radius-md);padding:1.25rem;text-align:center;color:var(--text-secondary);transition:background var(--duration-fast),border-color var(--duration-fast);cursor:pointer;background:var(--surface-card)}.dropzone.dragging{border-color:var(--color-primary);background:var(--color-primary-subtle);color:var(--color-primary)}.dropzone input[type=file]{display:none}.filter-bar{display:grid;gap:.5rem;margin-bottom:.85rem}.tabs{display:flex;gap:.35rem;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:.15rem}.tabs::-webkit-scrollbar{display:none}.tab{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;min-height:0;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--surface-primary);color:var(--text-secondary);font-size:.85rem;white-space:nowrap;cursor:pointer}.tab:hover:not(.tab-active){background:var(--surface-card-hover);color:var(--text-primary)}.tab-active{background:var(--color-primary);border-color:var(--color-primary);color:var(--text-inverse);font-weight:var(--font-weight-semibold)}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;padding:0 .4rem;height:1.15rem;border-radius:var(--radius-full);background:#ffffff40;font-size:.7rem;font-variant-numeric:tabular-nums}.tab:not(.tab-active) .tab-count{background:var(--surface-card);color:var(--text-tertiary)}.filter-row{display:flex;gap:.5rem;align-items:center}.chip{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .65rem;min-height:0;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--surface-primary);color:var(--text-secondary);font-size:.8rem;white-space:nowrap;cursor:pointer}.chip-active{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.search-input{flex:1;min-height:0;padding:.35rem .7rem;font-size:.85rem}.switcher{position:relative;flex:1;min-width:0}.switcher-trigger{display:flex;align-items:center;padding:.35rem .75rem;min-height:0;max-width:100%;font-size:1rem;font-weight:var(--font-weight-semibold);color:var(--text-primary);background:transparent;border:1px solid transparent}.switcher-trigger:hover:not(:disabled){background:var(--surface-card-hover);border-color:var(--color-border)}.switcher-menu{position:absolute;top:calc(100% + .25rem);left:0;width:min(320px,calc(100vw - 2rem));background:var(--surface-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-sticky);padding:.5rem;display:grid;gap:.4rem}.switcher-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.45rem .6rem;min-height:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-primary);text-align:left;font-size:.9rem}.switcher-item:hover:not(:disabled){background:var(--surface-card-hover)}.switcher-item-active{background:var(--color-primary-subtle);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.summary-row{display:flex;gap:1.25rem;padding:.75rem 1rem;background:var(--surface-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:.85rem;font-size:.95rem}.group-header{display:flex;justify-content:space-between;align-items:baseline;padding:0 .25rem .4rem;margin-bottom:.25rem;border-bottom:1px solid var(--border-subtle)}.count-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .55rem;border-radius:var(--radius-full);background:var(--surface-card);color:var(--text-secondary);font-size:.75rem;white-space:nowrap}.count-pill-urgent{background:#fef2f2;color:#b91c1c}@media (max-width: 420px){.page{padding:.75rem}.card{padding:.85rem}.filter-row{flex-wrap:wrap}.search-input{width:100%}}
