:root{
  --bg:#ffffff; --panel:#f4f5f7; --ink:#1c1d21; --muted:#6b6f76; --line:#e3e4e8;
  --del-bg:#ffe1e1; --del-ink:#9b1c1c; --ins-bg:#d8f5e1; --ins-ink:#10662f;
  --link:#1a55c4; --chip:#eceef1; --th-top:64px; --ok:#10662f;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:14px;line-height:1.45}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

.hdr{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 20px 8px}
.hdr h1{margin:0;font-size:19px;letter-spacing:-.01em}
.sub{margin:4px 0 0;color:var(--muted);font-size:13px}
.typechip .tcx{display:inline-flex;align-items:center;gap:6px;background:#eef3ff;color:#1a55c4;border:1px solid #c7d7f5;border-radius:12px;padding:1px 4px 1px 9px;font-size:12px;font-weight:600;margin-left:6px;white-space:nowrap}
.typechip .tcx button{border:none;background:none;color:#1a55c4;font-size:15px;line-height:1;cursor:pointer;padding:0 3px;border-radius:8px}
.typechip .tcx button:hover{background:#d6e3fb}
.account{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--muted);white-space:nowrap}
.account .who{font-weight:600;color:var(--ink)}
.account .role{background:var(--chip);border-radius:6px;padding:1px 7px;font-size:11px}
.account .lnk{cursor:pointer;color:var(--link);font-weight:600}
.account .lnk:hover{text-decoration:underline}

/* single sticky band: ONE toolbar row holds every control + the count */
.sticky{position:sticky;top:0;z-index:30;background:var(--bg);border-bottom:1px solid var(--line)}
.toolbar{display:flex;gap:7px;flex-wrap:wrap;align-items:center;padding:8px 20px}
.search{flex:1 1 200px;min-width:150px;padding:7px 10px;border:1px solid var(--line);border-radius:7px;font-size:13px;font-family:inherit}
.sel,.date{padding:6px 8px;border:1px solid var(--line);border-radius:7px;background:var(--bg);font-size:12px;font-family:inherit;color:var(--ink)}
.sel.sm{padding:5px 6px}
.datelbl,.pglbl{font-size:11px;color:var(--muted);display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.date{font-size:12px}
.btn{padding:6px 11px;border:1px solid var(--line);border-radius:7px;background:var(--panel);cursor:pointer;font-size:12px}
.btn:hover{background:#e7e9ec}
.viewtoggle{font-size:11px;color:var(--muted);display:inline-flex;gap:4px;align-items:center;white-space:nowrap}
.count{font-size:12px;color:var(--muted);margin-left:auto;white-space:nowrap} .count b{color:var(--ink)}

/* multi-select dropdown */
.ms{position:relative;font-size:12px}
.ms-btn{padding:6px 9px;border:1px solid var(--line);border-radius:7px;background:var(--bg);cursor:pointer;font-size:12px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;max-width:200px}
.ms-btn:hover{background:var(--panel)}
.ms-btn .cnt{background:var(--ink);color:#fff;border-radius:9px;padding:0 6px;font-size:10px;font-weight:600}
.ms-btn .caret{color:var(--muted);font-size:10px}
.ms-pop{position:absolute;top:calc(100% + 4px);left:0;z-index:50;background:var(--bg);border:1px solid var(--line);border-radius:9px;box-shadow:0 8px 28px rgba(0,0,0,.14);padding:6px;min-width:200px;max-height:340px;overflow:auto}
.ms-pop.hidden{display:none}
.ms-search{width:100%;padding:5px 8px;border:1px solid var(--line);border-radius:6px;font-size:12px;margin-bottom:5px}
.ms-opt{display:flex;align-items:center;gap:7px;padding:4px 6px;border-radius:6px;cursor:pointer;font-size:12px}
.ms-opt:hover{background:var(--panel)}
.ms-opt input{margin:0}
.ms-actions{display:flex;justify-content:space-between;border-top:1px solid var(--line);margin-top:5px;padding-top:5px}
.ms-actions a{cursor:pointer;font-size:11px;color:var(--link)}

.wrap{padding:0 20px 60px}
.tbl{width:100%;border-collapse:collapse;table-layout:fixed}
.tbl thead th{position:sticky;top:var(--th-top);z-index:5;background:var(--panel);text-align:left;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line);box-shadow:inset 0 -1px 0 var(--line)}
.tbl tbody td{padding:10px;border-bottom:1px solid var(--line);vertical-align:top}
.tbl tbody tr:nth-child(even){background:#fbfbfc}
.tbl tbody tr:hover{background:#f3f6fb}
.tbl tbody tr.approved{background:#f4fbf6}
.tbl tbody tr.approved:hover{background:#eef8f1}

.c-appr{width:42px;text-align:center} .c-page{width:13%} .c-field{width:9%} .c-reason{width:15%} .c-meta{width:10%}
.c-change{width:50%} .c-half{width:25%}

.appr-cell{text-align:center}
.appr-box{width:17px;height:17px;cursor:pointer;accent-color:var(--ok)}
.appr-who{display:block;font-size:9.5px;color:var(--ok);margin-top:3px;line-height:1.2}

.brand{display:inline-block;background:var(--chip);border-radius:6px;padding:2px 7px;font-size:11px;color:#3a3d44;font-weight:600;margin-bottom:4px}
.page-slug{font-family:var(--mono);font-size:12px;word-break:break-word;display:block}
.field{font-family:var(--mono);font-size:11.5px;color:#3a3d44;background:var(--panel);border:1px solid var(--line);border-radius:5px;padding:1px 5px;display:inline-block;word-break:break-all}

.diff{font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word;max-height:230px;overflow:auto}
.diff del{background:var(--del-bg);color:var(--del-ink);text-decoration:line-through;border-radius:2px;padding:0 1px}
.diff ins{background:var(--ins-bg);color:var(--ins-ink);text-decoration:none;border-radius:2px;padding:0 1px}
.diff .lk{display:block;padding:2px 0;border-bottom:1px solid #f0f0f0;font-size:12px}
.diff .lk:last-child{border-bottom:none}
.htmlonly{font-style:italic;color:var(--muted);font-size:11.5px;display:block;margin-bottom:3px}
.reason{font-size:12px;color:#44474d;max-height:200px;overflow:auto}
.rsn-item{padding:2px 0 2px 11px;position:relative;line-height:1.45}
.rsn-item+.rsn-item{border-top:1px solid var(--line);margin-top:3px}
.rsn-item::before{content:"›";position:absolute;left:0;color:var(--muted)}
.meta-user{font-size:12px;font-weight:600}
.meta-date{font-size:12px;color:var(--muted);margin-top:1px}
.meta-pr{font-family:var(--mono);font-size:12px;margin-top:3px;display:inline-block}
.state-OPEN{color:#9a6700} .state-MERGED{color:#10662f}

.tbl.inline .col-side{display:none}
.tbl:not(.inline) .col-change{display:none}

.empty{padding:30px;text-align:center;color:var(--muted)}
.pager{display:flex;gap:6px;justify-content:center;align-items:center;margin-top:16px;flex-wrap:wrap}
.pager button{min-width:34px;padding:6px 10px;border:1px solid var(--line);border-radius:7px;background:var(--bg);cursor:pointer;font-size:13px}
.pager button[disabled]{opacity:.4;cursor:default}
.pager button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager .pggap{color:var(--muted);padding:0 2px}
.ft{padding:18px 20px;color:var(--muted);font-size:12px;border-top:1px solid var(--line)}

/* overlays: login + users modal */
.overlay{position:fixed;inset:0;z-index:100;background:rgba(20,22,28,.45);display:flex;align-items:center;justify-content:center;padding:20px}
.login-card,.modal-card{background:var(--bg);border:1px solid var(--line);border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.22);padding:28px;width:100%}
.login-card{max-width:380px;text-align:center}
.login-card h2{margin:0 0 6px;font-size:19px}
.login-sub{color:var(--muted);font-size:13px;margin:0 0 18px}
.li-input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font-size:14px;margin-bottom:9px;font-family:inherit}
.li-btn{width:100%;padding:10px;border:none;border-radius:8px;background:var(--ink);color:#fff;font-size:14px;font-weight:600;cursor:pointer}
.li-btn:hover{background:#000}
.li-msg{font-size:12.5px;color:#9b1c1c;margin:10px 0 0;min-height:16px}
.li-msg.ok{color:var(--ok)}

.modal-card{max-width:760px;max-height:86vh;overflow:auto}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.modal-head h2{margin:0;font-size:18px}
.utbl{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}
.utbl th{text-align:left;font-size:11px;text-transform:uppercase;color:var(--muted);padding:6px 8px;border-bottom:1px solid var(--line)}
.utbl td{padding:7px 8px;border-bottom:1px solid var(--line);vertical-align:middle}
.utbl .u-role{background:var(--chip);border-radius:6px;padding:1px 7px;font-size:11px}
.u-del{cursor:pointer;color:#9b1c1c;font-size:12px;border:none;background:none}
.user-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:8px}
.user-form .li-input{width:auto;flex:1 1 130px;margin-bottom:0}
.user-form .li-btn{width:auto;flex:0 0 auto;padding:9px 16px}
