:root{color-scheme:light;font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif;color:#172033;background:#edf1f6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}h1,h2,p{margin:0}h1{color:#172033;font-size:28px;line-height:1.18}h2{color:#172033;font-size:16px;line-height:1.25}.auth-shell{display:grid;min-height:100vh;place-items:center;background:linear-gradient(135deg,rgba(47,128,237,.12),transparent 34%),#edf1f6;padding:24px}.login-card{width:min(460px,100%);border:1px solid #dbe3ee;border-radius:10px;background:#fff;padding:28px;box-shadow:0 24px 60px #10182724}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.login-brand strong,.login-brand span{display:block}.login-brand strong{color:#172033;font-size:16px}.login-brand span{margin-top:3px;color:#65748a;font-size:13px}.login-copy{margin-bottom:20px}.login-form{display:grid;gap:14px}.login-security{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}.login-security span{border:1px solid #dbe3ee;border-radius:999px;background:#f8fafc;color:#526179;padding:5px 9px;font-size:12px;font-weight:800}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;display:grid;grid-template-rows:auto auto 1fr auto;min-height:100vh;border-right:1px solid #101827;background:#101827;color:#e8edf5;padding:20px 16px}.brand{display:flex;align-items:center;gap:12px;padding:4px 4px 20px}.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:8px;background:#2f80ed;color:#fff;font-size:14px;font-weight:900}.brand strong,.brand span{display:block}.brand strong{font-size:15px}.brand span{margin-top:3px;color:#9aa7bc;font-size:12px}.side-nav{display:grid;gap:6px;padding-top:8px}.side-nav button{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;border:0;border-radius:8px;background:transparent;color:#aeb9ca;padding:10px 12px;font-size:14px;font-weight:800;text-align:left;text-decoration:none}.side-nav button strong{color:#7f8ca3;font-size:12px}.side-nav button:hover,.side-nav button.active{background:#1b2638;color:#fff}.side-nav button:hover strong,.side-nav button.active strong{color:#fff}.sidebar-status{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #263449;border-radius:8px;background:#151f2e;padding:12px}.sidebar-status span{color:#9aa7bc;font-size:12px;font-weight:800}.sidebar-status strong{color:#9aa7bc;font-size:13px}.sidebar-status strong.ok{color:#58d29b}.sidebar-status strong.error{color:#ff8f89}.main-stage{min-width:0;padding:24px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.eyebrow{margin:0 0 5px;color:#65748a;font-size:13px;font-weight:900;letter-spacing:0}.top-actions{display:flex;align-items:center;gap:10px}.sync-note{color:#65748a;font-size:13px;font-weight:800;white-space:nowrap}.status{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 12px;border:1px solid #d6deea;border-radius:8px;background:#fff;color:#65748a;font-size:14px;font-weight:900;white-space:nowrap}.status-dot{width:9px;height:9px;border-radius:999px;background:#98a6ba}.status.ok .status-dot{background:#12825f}.status.error .status-dot{background:#c43d3a}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.metric{position:relative;overflow:hidden;min-height:88px;border:1px solid #dbe3ee;border-radius:8px;background:#fff;padding:16px;box-shadow:0 1px 2px #1018270a}.metric.accent{border-color:#b9d5fb}.metric.accent:before{position:absolute;top:0;left:0;width:4px;height:100%;background:#2f80ed;content:""}.metric span{display:block;color:#65748a;font-size:12px;font-weight:900}.metric strong{display:block;margin-top:10px;color:#172033;font-size:30px;line-height:1}.metric small{display:block;margin-top:8px;color:#7d8ca1;font-size:12px;font-weight:800}.page-view{min-width:0}.panel{border:1px solid #dbe3ee;border-radius:8px;background:#fff;box-shadow:0 1px 2px #1018270a}.package-panel,.table-panel,.users-panel{padding:18px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.panel-heading p{margin-top:5px;color:#65748a;font-size:13px}.toolbar-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.filters,.user-form,.modal-form{display:grid;gap:12px}label{display:grid;gap:6px}label span{color:#526179;font-size:12px;font-weight:900}.field-help{color:#65748a;font-size:12px;line-height:1.5}input,select{width:100%;min-height:40px;border:1px solid #cbd5e1;border-radius:7px;background:#fff;color:#172033;padding:8px 10px;outline:none}input::placeholder{color:#9ba8bb}input:focus,select:focus{border-color:#2f80ed;box-shadow:0 0 0 3px #2f80ed24}.user-form{grid-template-columns:minmax(150px,.7fr) minmax(160px,.7fr) minmax(150px,.7fr) auto minmax(260px,1.4fr) auto;align-items:end;margin-bottom:14px}.filters{grid-template-columns:minmax(160px,1fr) minmax(140px,.9fr) minmax(130px,.7fr) 92px auto auto;align-items:end;margin-bottom:14px}.switch-row{display:inline-flex;align-items:center;gap:8px;min-height:40px}.switch-row input{width:18px;min-height:18px}.select-col{width:42px;text-align:center}.select-col input{width:16px;min-height:16px}.primary-btn,.ghost-btn,.danger-btn{min-height:40px;border-radius:7px;padding:0 14px;font-weight:900;white-space:nowrap}.primary-btn{border:1px solid #2f80ed;background:#2f80ed;color:#fff}.primary-btn:hover:not(:disabled){background:#246dcb}.ghost-btn{border:1px solid #cbd5e1;background:#fff;color:#253247}.ghost-btn:hover:not(:disabled){background:#f5f7fb}.danger-btn{border:1px solid #e6b4b2;background:#fff;color:#a33431}.danger-btn:hover:not(:disabled){background:#fff3f2}.compact{min-width:72px}.message{margin:8px 0 12px;border-radius:7px;padding:10px 12px;font-size:14px}.message.error{border:1px solid #e6b4b2;background:#fff3f2;color:#a33431}.message.success{border:1px solid #a8d8c4;background:#effaf5;color:#14734c}.package-badge{border:1px solid #a8d8c4;border-radius:999px;background:#effaf5;color:#14734c;padding:5px 10px;font-size:12px;font-weight:900;white-space:nowrap}.package-badge.disabled{border-color:#d3dbe7;background:#f2f5f9;color:#65748a}.row-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.permission-picker{display:grid;gap:6px}.permission-picker>span{color:#526179;font-size:12px;font-weight:900}.permission-options{display:flex;flex-wrap:wrap;gap:7px}.permission-options.inline{max-width:520px}.check-chip{display:inline-flex;align-items:center;gap:6px;min-height:32px;border:1px solid #dbe3ee;border-radius:7px;background:#f8fafc;color:#253247;padding:5px 8px}.check-chip input{width:14px;min-height:14px}.check-chip span{color:inherit;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:12px;font-weight:800}.table-wrap{overflow:auto;border:1px solid #e4eaf2;border-radius:8px}.compact-table table{min-width:760px}.users-table table{min-width:980px}.compact-table th,.compact-table td{padding:10px 11px}.actions-col{text-align:right;width:160px}table{width:100%;min-width:1100px;border-collapse:collapse;font-size:14px}th,td{border-bottom:1px solid #e7edf5;padding:11px 12px;text-align:left;vertical-align:top}th{position:sticky;top:0;background:#f8fafc;color:#526179;font-size:12px;font-weight:900}tbody tr:last-child td{border-bottom:0}tbody tr:hover td{background:#fbfcfe}tbody tr.muted td{background:#f7f9fc;color:#7d8ca1}td{color:#253247}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:13px}.time-primary{white-space:nowrap}.time-source{color:#65748a;white-space:nowrap}.empty{height:96px;color:#7d8ca1;text-align:center;vertical-align:middle}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:14px;color:#65748a;font-size:14px}.security-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.security-strip div{border:1px solid #dbe3ee;border-radius:8px;background:#fff;padding:13px 14px}.security-strip span,.security-strip strong{display:block}.security-strip span{color:#65748a;font-size:12px;font-weight:900}.security-strip strong{margin-top:5px;color:#14734c;font-size:14px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#1018276b;padding:20px}.modal{width:min(520px,100%);border:1px solid #dbe3ee;border-radius:8px;background:#fff;padding:18px;box-shadow:0 24px 60px #1018272e}.modal-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.modal-heading p{margin-top:5px;color:#65748a;font-size:13px}.modal-form{grid-template-columns:1fr}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}@media(max-width:1240px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;min-height:auto;grid-template-columns:1fr;padding:14px 16px}.brand{padding-bottom:12px}.side-nav{grid-auto-flow:column;grid-auto-columns:max-content;overflow-x:auto;padding-bottom:4px}.side-nav button{min-width:128px}.sidebar-status{display:none}.summary-grid,.security-strip,.user-form{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:920px){.main-stage{padding:16px}.topbar,.top-actions,.panel-heading{align-items:stretch;flex-direction:column}.toolbar-actions{justify-content:flex-start}.sync-note{white-space:normal}.filters,.user-form{grid-template-columns:1fr 1fr}}@media(max-width:560px){h1{font-size:24px}.summary-grid,.filters,.user-form,.security-strip{grid-template-columns:1fr}.metric{min-height:76px}.package-panel,.table-panel,.users-panel{padding:14px}.compact,.primary-btn,.ghost-btn,.danger-btn{width:100%}.pagination,.modal-actions,.modal-heading{align-items:stretch;flex-direction:column}}
