:root{--bg: #f6f7f9;--bg-alt: #eef0f4;--surface: #ffffff;--surface-2: #fafbfc;--border: #e3e6eb;--border-strong: #cfd4dc;--divider: #edeff3;--text: #0f1722;--text-2: #3a4454;--text-3: #6b7687;--text-4: #9aa3b2;--primary: oklch(.52 .11 245);--primary-hover: oklch(.46 .12 245);--primary-soft: oklch(.95 .03 245);--primary-ink: oklch(.32 .08 245);--accent: oklch(.72 .14 70);--accent-soft: oklch(.96 .04 75);--accent-ink: oklch(.45 .12 60);--ok: oklch(.62 .14 150);--ok-soft: oklch(.95 .04 150);--ok-ink: oklch(.4 .14 150);--warn: oklch(.75 .15 80);--warn-soft: oklch(.96 .05 85);--warn-ink: oklch(.48 .14 70);--danger: oklch(.58 .19 25);--danger-soft: oklch(.95 .04 25);--danger-ink: oklch(.42 .18 25);--info: oklch(.62 .12 230);--info-soft: oklch(.95 .03 230);--info-ink: oklch(.42 .12 230);--neutral: oklch(.62 0 0);--neutral-soft: oklch(.94 0 0);--scrim: rgba(15, 23, 34, .35);--scrim-strong: rgba(15, 23, 34, .45);--r-sm: 4px;--r-md: 6px;--r-lg: 10px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .04);--shadow-md: 0 4px 12px rgba(16, 24, 40, .06), 0 1px 2px rgba(16, 24, 40, .04);--shadow-lg: 0 12px 32px rgba(16, 24, 40, .12);--sidebar-w: 232px;--topbar-h: 52px;--subbar-h: 44px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace}[data-theme=graphite]{--bg: #f4f2ee;--bg-alt: #eae6df;--surface: #fdfcf9;--surface-2: #f8f6f1;--border: #e1dcd2;--border-strong: #c8c0b1;--divider: #ebe6da;--text: #1a1815;--text-2: #3d3831;--text-3: #6e665a;--text-4: #9e9686;--primary: oklch(.42 .04 60);--primary-hover: oklch(.34 .04 60);--primary-soft: oklch(.92 .02 70);--primary-ink: oklch(.28 .04 60);--accent: oklch(.62 .15 55);--accent-soft: oklch(.94 .04 60);--accent-ink: oklch(.42 .14 50)}[data-theme=dark]{--bg: #0d1117;--bg-alt: #161b22;--surface: #1c2230;--surface-2: #252d3c;--border: #2a3140;--border-strong: #3a4252;--divider: #232a37;--text: #e6edf3;--text-2: #c0c8d2;--text-3: #8b949e;--text-4: #6e7681;--primary: oklch(.7 .13 245);--primary-hover: oklch(.78 .13 245);--primary-soft: oklch(.28 .08 245);--primary-ink: oklch(.85 .1 245);--accent: oklch(.78 .14 70);--accent-soft: oklch(.32 .08 70);--accent-ink: oklch(.88 .12 70);--ok-soft: oklch(.3 .08 150);--ok-ink: oklch(.85 .14 150);--warn-soft: oklch(.32 .1 80);--warn-ink: oklch(.88 .14 80);--danger-soft: oklch(.3 .1 25);--danger-ink: oklch(.78 .18 25);--info-soft: oklch(.3 .08 230);--info-ink: oklch(.85 .12 230);--neutral-soft: oklch(.28 0 0);--scrim: rgba(0, 0, 0, .55);--scrim-strong: rgba(0, 0, 0, .7);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5)}html[data-density=compact] body{font-size:12.5px;line-height:1.4}html[data-density=compact] .page{padding:14px 18px 36px}html[data-density=compact] .page-head{margin-bottom:12px}html[data-density=compact] .page-title{font-size:19px}html[data-density=compact] .page-sub{font-size:11.5px}html[data-density=compact] .grid{gap:8px}html[data-density=compact] .card-head{padding:9px 13px}html[data-density=compact] .card-body{padding:12px 13px}html[data-density=compact] .card-title{font-size:12.5px}html[data-density=compact] .card-sub{font-size:11px}html[data-density=compact] .table{font-size:12px}html[data-density=compact] .table th{padding:6px 12px;font-size:10px}html[data-density=compact] .table td{padding:6px 12px}html[data-density=compact] .table td.mono{font-size:11.5px}html[data-density=compact] .kpi{padding:10px 13px}html[data-density=compact] .kpi-label{font-size:10px}html[data-density=compact] .kpi-value{font-size:22px}html[data-density=compact] .kpi-value .unit{font-size:11px}html[data-density=compact] .kpi-delta{font-size:10.5px;margin-top:4px}html[data-density=compact] .btn{padding:4px 10px;font-size:11.5px}html[data-density=compact] .btn.sm{padding:3px 7px;font-size:11px}html[data-density=compact] .chip{padding:1px 6px;font-size:10.5px}html[data-density=compact] .tabs{padding:0 4px}html[data-density=compact] .tab{padding:7px 11px;font-size:11.5px}html[data-density=compact] .filters{padding:6px 12px}html[data-density=compact] .filter-input{padding:3px 8px;font-size:11px}html[data-density=compact] .sb-item{padding:5px 12px;font-size:12px}html[data-density=compact] .sb-section{margin-bottom:10px}html[data-density=compact] .topbar{padding:0 16px}html[data-density=spacious] body{font-size:13.5px;line-height:1.55}html[data-density=spacious] .page{padding:28px 32px 64px}html[data-density=spacious] .page-head{margin-bottom:24px}html[data-density=spacious] .page-title{font-size:26px}html[data-density=spacious] .page-sub{font-size:13.5px;margin-top:5px}html[data-density=spacious] .grid{gap:18px}html[data-density=spacious] .card-head{padding:16px 20px}html[data-density=spacious] .card-body{padding:20px}html[data-density=spacious] .card-title{font-size:14px}html[data-density=spacious] .card-sub{font-size:12.5px;margin-top:3px}html[data-density=spacious] .table{font-size:13.5px}html[data-density=spacious] .table th{padding:14px 18px;font-size:11.5px}html[data-density=spacious] .table td{padding:14px 18px}html[data-density=spacious] .table td.mono{font-size:13px}html[data-density=spacious] .kpi{padding:18px 20px}html[data-density=spacious] .kpi-label{font-size:12px}html[data-density=spacious] .kpi-value{font-size:32px}html[data-density=spacious] .kpi-value .unit{font-size:15px}html[data-density=spacious] .kpi-delta{font-size:12.5px;margin-top:8px}html[data-density=spacious] .btn{padding:8px 14px;font-size:13px}html[data-density=spacious] .btn.sm{padding:6px 10px;font-size:12px}html[data-density=spacious] .chip{padding:3px 10px;font-size:11.5px}html[data-density=spacious] .tab{padding:13px 18px;font-size:13.5px}html[data-density=spacious] .filters{padding:14px 18px}html[data-density=spacious] .filter-input{padding:7px 12px;font-size:12.5px}html[data-density=spacious] .sb-item{padding:9px 14px;font-size:13.5px}html[data-density=spacious] .sb-section{margin-bottom:18px}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:13px;line-height:1.45;height:100%;overflow:hidden}#root{height:100%}button{font-family:inherit;font-size:inherit;color:inherit;border:none;background:none;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}.mono{font-family:var(--font-mono);font-feature-settings:"tnum"}.num{font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--text-4)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.card-head{padding:12px 16px;border-bottom:1px solid var(--divider);display:flex;align-items:center;justify-content:space-between;gap:12px}.card-title{font-size:13px;font-weight:600;color:var(--text)}.card-sub{font-size:11.5px;color:var(--text-3);margin-top:2px}.card-body{padding:16px}.card-body.flush{padding:0;overflow-x:auto}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-md);font-size:12.5px;font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:all .12s}.btn:hover{background:var(--bg-alt);border-color:var(--border-strong)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn.danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn.danger:hover{filter:brightness(.95)}.btn.ghost{border-color:transparent;background:transparent;color:var(--text-2)}.btn.ghost:hover{background:var(--bg-alt);color:var(--text)}.btn.sm{padding:4px 8px;font-size:11.5px}.btn.icon{padding:6px}.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500;background:var(--bg-alt);color:var(--text-2);border:1px solid transparent;white-space:nowrap}.chip.ok{background:var(--ok-soft);color:var(--ok-ink)}.chip.warn{background:var(--warn-soft);color:var(--warn-ink)}.chip.danger{background:var(--danger-soft);color:var(--danger-ink)}.chip.info{background:var(--info-soft);color:var(--info-ink)}.chip.accent{background:var(--accent-soft);color:var(--accent-ink)}.chip.outline{background:transparent;border-color:var(--border);color:var(--text-2)}.chip .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.table{width:100%;border-collapse:collapse;font-size:12.5px}.table th{text-align:left;font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;position:sticky;top:0;cursor:pointer;-webkit-user-select:none;user-select:none}.table th:hover{color:var(--text)}.table th .sort-icon{opacity:.4;margin-left:4px}.table th.sorted .sort-icon{opacity:1;color:var(--primary)}.table td{padding:10px 14px;border-bottom:1px solid var(--divider);color:var(--text);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr{cursor:pointer;transition:background .1s}.table tbody tr:hover{background:var(--surface-2)}.table tbody tr.selected{background:var(--primary-soft)}.table td.num,.table th.num{text-align:right;font-family:var(--font-mono)}.table td.mono{font-family:var(--font-mono);font-size:12px}.kpi{display:flex;flex-direction:column;gap:2px;padding:14px 16px}.kpi-label{font-size:11px;color:var(--text-3);font-weight:500;letter-spacing:.03em;text-transform:uppercase}.kpi-value{font-size:26px;font-weight:600;font-family:var(--font-mono);letter-spacing:-.02em;color:var(--text);margin-top:2px}.kpi-value .unit{font-size:13px;color:var(--text-3);margin-left:4px;font-weight:400}.kpi-delta{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;margin-top:6px;font-weight:500}.kpi-delta.up{color:var(--ok)}.kpi-delta.down{color:var(--danger)}.kpi-delta.flat{color:var(--text-3)}.kpi-spark{margin-top:10px;height:36px}.grid{display:grid;gap:12px}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-sidebar{grid-template-columns:2fr 1fr}.progress{height:6px;background:var(--bg-alt);border-radius:6px;overflow:hidden;position:relative}.progress-fill{height:100%;background:var(--primary);border-radius:6px;transition:width .3s}.progress-fill.ok{background:var(--ok)}.progress-fill.warn{background:var(--warn)}.progress-fill.danger{background:var(--danger)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);padding:0 4px}.tab{padding:10px 14px;font-size:12.5px;font-weight:500;color:var(--text-3);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer}.tab:hover{color:var(--text)}.tab.active{color:var(--primary-ink);border-bottom-color:var(--primary)}.tab .count{font-family:var(--font-mono);font-size:10.5px;background:var(--bg-alt);padding:1px 6px;border-radius:10px;margin-left:6px;color:var(--text-3)}.filters{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--divider);background:var(--surface-2);flex-wrap:wrap}.filter-input{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);font-size:12px;color:var(--text-2);cursor:pointer}.filter-input:hover{border-color:var(--border-strong)}.filter-input input{border:none;outline:none;background:transparent;width:180px;font-size:12px}.filter-input select{border:none;outline:none;background:transparent;font-size:12px;cursor:pointer}.filter-input .fi-label{color:var(--text-3);font-size:11px}.filter-input .fi-value{color:var(--text);font-weight:500}.s-input{padding:7px 10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-size:13px;font-family:inherit;outline:none;min-width:200px;transition:border-color .1s}.s-input:focus{border-color:var(--primary)}.s-input.wide{min-width:280px}.s-input.full{min-width:0;width:100%}.s-textarea{padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-size:13px;font-family:inherit;outline:none;width:100%;resize:vertical;min-height:72px}.s-select{padding:7px 28px 7px 10px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-size:13px;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-3) 50%),linear-gradient(135deg,var(--text-3) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;cursor:pointer}.toggle{position:relative;width:38px;height:22px;background:var(--border-strong);border-radius:22px;cursor:pointer;transition:background .15s;flex-shrink:0;border:none;padding:0}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .15s;box-shadow:0 1px 2px #00000026}.toggle.on{background:var(--primary)}.toggle.on:after{transform:translate(16px)}.settings-layout{display:grid;grid-template-columns:220px 1fr;gap:20px;align-items:flex-start}.settings-nav{position:sticky;top:0;display:flex;flex-direction:column;gap:2px}.settings-nav-section{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);padding:8px 12px 4px;font-weight:600;margin-top:8px}.settings-nav-section:first-child{margin-top:0}.settings-nav button{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-md);font-size:13px;color:var(--text-2);text-align:left}.settings-nav button:hover{background:var(--bg-alt);color:var(--text)}.settings-nav button.active{background:var(--primary-soft);color:var(--primary-ink);font-weight:500}.settings-section{margin-bottom:16px}.settings-section-head{margin-bottom:12px}.settings-section-title{font-size:18px;font-weight:600;letter-spacing:-.01em}.settings-section-sub{font-size:12.5px;color:var(--text-3);margin-top:2px}.s-row{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--divider)}.s-row:last-child{border-bottom:none}.s-row-label{font-size:13px;font-weight:500;color:var(--text)}.s-row-sub{font-size:12px;color:var(--text-3);margin-top:2px;line-height:1.4}.notif-pref-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 18px;border-bottom:1px solid var(--divider);flex-wrap:wrap}.notif-pref-row:last-child{border-bottom:none}.notif-pref-info{flex:1 1 260px;min-width:0}.notif-pref-channels{display:flex;gap:6px;flex-shrink:0}.chan-pill{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:66px;padding:4px 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-3);font-size:11.5px;font-weight:500;cursor:pointer;white-space:nowrap;transition:border-color .12s,background .12s,color .12s}.chan-pill:hover:not(.on){border-color:var(--border-strong);color:var(--text-2)}.chan-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--text-4);transition:background .12s}.chan-pill.on{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-ink)}.chan-pill.on .dot{background:var(--primary)}.chan-pill-empty{display:inline-flex;align-items:center;justify-content:center;min-width:66px}.chan-pill-empty span{width:10px;height:1px;background:var(--border-strong)}.avatar{width:24px;height:24px;border-radius:50%;background:var(--primary-soft);color:var(--primary-ink);display:inline-grid;place-items:center;font-size:10px;font-weight:600;letter-spacing:.02em;flex-shrink:0}.avatar.sm{width:20px;height:20px;font-size:9px}.avatar.lg{width:40px;height:40px;font-size:14px}.avatar-stack{display:inline-flex}.avatar-stack .avatar{border:2px solid var(--surface);margin-left:-6px}.avatar-stack .avatar:first-child{margin-left:0}.dl{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:12.5px}.dl dt{color:var(--text-3)}.dl dd{margin:0;color:var(--text);font-weight:500}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim);z-index:200;animation:fade .15s}@keyframes fade{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;width:680px;max-width:95vw;background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);z-index:201;display:flex;flex-direction:column;animation:slidein .2s ease-out}@keyframes slidein{0%{transform:translate(30px);opacity:0}to{transform:none;opacity:1}}.drawer-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.drawer-body{flex:1;overflow-y:auto;padding:20px}.drawer-foot{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim-strong);z-index:250;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade .15s}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:calc(100vh - 48px);width:100%;animation:modalin .18s ease-out;overflow:hidden}@keyframes modalin{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}.modal-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-shrink:0}.modal-title{font-size:14px;font-weight:600;color:var(--text)}.modal-sub{font-size:12px;color:var(--text-3);margin-top:2px}.modal-body{flex:1;overflow-y:auto;padding:18px}.modal-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:8px;flex-shrink:0;background:var(--surface)}.tweaks{position:fixed;bottom:20px;right:20px;width:280px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;font-size:12.5px}.tweaks-head{padding:10px 14px;border-bottom:1px solid var(--divider);display:flex;align-items:center;justify-content:space-between;background:var(--surface-2)}.tweaks-head .t-title{font-weight:600;font-size:13px}.tweaks-body{padding:14px;display:flex;flex-direction:column;gap:14px}.tweak-row{display:flex;flex-direction:column;gap:6px}.tweak-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);font-weight:600}.tweak-segment{display:flex;background:var(--bg-alt);border-radius:var(--r-md);padding:2px;gap:2px}.tweak-seg{flex:1;padding:6px 8px;border-radius:4px;font-size:11.5px;font-weight:500;color:var(--text-2);text-align:center;white-space:nowrap}.tweak-seg.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.tweak-seg:hover:not(.active){color:var(--text)}.pagination{display:flex;align-items:center;gap:6px;padding:10px 14px;border-top:1px solid var(--divider);background:var(--surface-2);font-size:12px;color:var(--text-3)}.pagination .spacer{flex:1}.page-btn{padding:4px 8px;border-radius:var(--r-md);font-size:12px;color:var(--text-2);border:1px solid var(--border);background:var(--surface);min-width:26px;text-align:center}.page-btn:hover:not(:disabled){background:var(--bg-alt)}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-btn.active{background:var(--primary-soft);color:var(--primary-ink);border-color:var(--primary)}.empty-state{padding:40px 20px;text-align:center;color:var(--text-3)}.palette-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim);z-index:250;animation:fade .12s}.palette{position:fixed;top:14vh;left:50%;transform:translate(-50%);width:92vw;max-width:640px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:251;display:flex;flex-direction:column;overflow:hidden;animation:slidedown .15s ease-out}@keyframes slidedown{0%{transform:translate(-50%) translateY(-14px);opacity:0}to{transform:translate(-50%);opacity:1}}.palette-input-row{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--divider)}.palette-input{flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--text)}.palette-input::placeholder{color:var(--text-4)}.palette-list{max-height:56vh;overflow-y:auto;padding:6px 0}.palette-group{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);font-weight:600;padding:10px 18px 4px}.palette-item{display:flex;align-items:center;gap:12px;width:100%;padding:8px 18px;font-size:13px;color:var(--text);text-align:left}.palette-item:hover,.palette-item.active{background:var(--primary-soft);color:var(--primary-ink)}.palette-item.active .palette-icon{color:var(--primary)}.palette-icon{color:var(--text-3);flex-shrink:0}.palette-label{flex:1}.palette-hint{font-size:11.5px;color:var(--text-3);margin-left:auto}.palette-item.active .palette-hint{color:var(--primary-ink);opacity:.7}.palette-foot{border-top:1px solid var(--divider);background:var(--surface-2);padding:8px 18px;display:flex;gap:16px;font-size:11px;color:var(--text-3)}.palette-foot .tb-kbd{margin-right:4px}.form-section{margin-bottom:18px}.form-section:last-child{margin-bottom:0}.form-section-title{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);font-weight:600;margin-bottom:10px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px 14px}.form-grid.full>.form-field{grid-column:1 / -1}.form-field{display:flex;flex-direction:column;gap:4px;min-width:0}.form-field.span-2{grid-column:1 / -1}.form-field-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3)}.form-field-label .req{color:var(--danger);margin-left:2px}.form-field-error{font-size:11px;color:var(--danger-ink);margin-top:2px}.form-field .s-input,.form-field .s-select,.form-field .s-textarea{width:100%;min-width:0}.form-field .s-input.invalid,.form-field .s-select.invalid,.form-field .s-textarea.invalid{border-color:var(--danger)}.permission-picker{display:flex;flex-direction:column;gap:10px}.permission-picker.is-disabled{opacity:.6;pointer-events:none}.permission-picker-empty{padding:10px 12px;border:1px dashed var(--divider);border-radius:6px;background:var(--surface-2)}.permission-picker-toolbar{display:flex;gap:10px;align-items:center}.permission-picker-toolbar .s-input{flex:1;min-width:0}.permission-picker-count{white-space:nowrap}.permission-picker-groups{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow-y:auto;border:1px solid var(--divider);border-radius:6px;padding:8px;background:var(--surface-2)}.permission-group{border:1px solid var(--divider);border-radius:6px;padding:6px 10px 8px;background:var(--surface);margin:0}.permission-group-head{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 0 6px}.permission-group-title{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);font-weight:700}.permission-group-actions{display:flex;gap:6px}.permission-group-btn{font-size:10px;letter-spacing:.04em;background:transparent;border:1px solid var(--divider);color:var(--text-2);padding:2px 6px;border-radius:3px;cursor:pointer}.permission-group-btn:hover:not(:disabled){background:var(--bg-alt);color:var(--text)}.permission-group-btn:disabled{opacity:.4;cursor:default}.permission-group-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2px 10px}.permission-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text);padding:3px 0;cursor:pointer;min-width:0}.permission-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.permission-item input[type=checkbox]{cursor:pointer;flex-shrink:0}.skeleton-row td{padding-top:11px;padding-bottom:11px}.skeleton-row{cursor:default!important}.skeleton-row:hover{background:transparent!important}.skeleton-bar{display:block;height:12px;border-radius:4px;background:linear-gradient(90deg,var(--bg-alt) 0%,var(--divider) 50%,var(--bg-alt) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.4s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.notif-list{display:flex;flex-direction:column}.notif-row{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid var(--divider)}.notif-row:last-child{border-bottom:none}.notif-bar{width:3px;flex-shrink:0;border-radius:2px}.notif-row.danger .notif-bar{background:var(--danger)}.notif-row.warn .notif-bar{background:var(--warn)}.notif-row.info .notif-bar{background:var(--info)}.notif-row.ok .notif-bar{background:var(--ok)}.notif-body{flex:1;min-width:0}.notif-title{font-weight:600;font-size:13px;color:var(--text)}.notif-meta{font-size:11px;color:var(--text-3);margin-top:2px;display:flex;gap:8px}.notif-msg{font-size:12px;color:var(--text-2);margin-top:4px;line-height:1.45}.notif-actions{display:flex;gap:4px;align-items:flex-start;flex-shrink:0}.toaster{position:fixed;top:16px;right:16px;z-index:300;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:var(--r-md);box-shadow:var(--shadow-md);font-size:12.5px;min-width:240px;max-width:360px;animation:toast-in .18s ease-out}@keyframes toast-in{0%{transform:translate(20px);opacity:0}to{transform:none;opacity:1}}.toast.success{border-left-color:var(--ok);color:var(--ok-ink)}.toast.error{border-left-color:var(--danger);color:var(--danger-ink)}.toast.info{border-left-color:var(--info);color:var(--info-ink)}.toast-msg{flex:1;color:var(--text);line-height:1.35}.toast-close{display:grid;place-items:center;width:22px;height:22px;border-radius:4px;color:var(--text-3)}.toast-close:hover{background:var(--bg-alt);color:var(--text)}.error-banner{background:var(--danger-soft);color:var(--danger-ink);border:1px solid var(--danger);border-radius:var(--r-md);padding:8px 12px;font-size:12.5px}.login-shell{display:grid;place-items:center;height:100vh;width:100vw;background:var(--bg);padding:20px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:28px}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:20px}.login-form{display:flex;flex-direction:column;gap:12px}.login-form label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3)}.login-form .field{display:flex;flex-direction:column;gap:4px}.login-form .s-input{width:100%;min-width:0}.flex{display:flex}.flex.col{flex-direction:column}.flex.center{align-items:center}.flex.between{justify-content:space-between}.gap-sm{gap:6px}.gap-md{gap:10px}.gap-lg{gap:16px}.text-muted{color:var(--text-3)}.text-sub{color:var(--text-2)}.text-xs{font-size:11px}.text-sm{font-size:12px}.fw-600{font-weight:600}.mt-0{margin-top:0}.mt-sm{margin-top:8px}.mt-md{margin-top:14px}.mt-lg{margin-top:20px}.spacer{flex:1}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:100%;height:100vh;width:100vw}.app[data-nav=top]{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.sb-brand{height:var(--topbar-h);padding:0 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-shrink:0}.sb-logo{width:26px;height:26px;flex-shrink:0;background:var(--primary);border-radius:5px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;letter-spacing:.5px;position:relative}.sb-logo:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:1.5px solid rgba(255,255,255,.45);border-radius:2px;border-top:none;border-left:none}.sb-brand-text{display:flex;flex-direction:column;line-height:1.15;min-width:0}.sb-brand-name{font-weight:600;font-size:13px;color:var(--text)}.sb-brand-sub{font-size:10.5px;color:var(--text-3);letter-spacing:.04em;text-transform:uppercase}.sb-scroll{overflow-y:auto;flex:1;padding:12px 8px}.sb-section{margin-bottom:14px}.sb-section-label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);padding:4px 12px 6px;font-weight:600}.sb-item{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:var(--r-md);color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%;text-align:left}.sb-item:hover{background:var(--bg-alt);color:var(--text)}.sb-item.active{background:var(--primary-soft);color:var(--primary-ink)}.sb-item.active .sb-icon{color:var(--primary)}.sb-icon{width:16px;height:16px;flex-shrink:0;color:var(--text-3)}.sb-badge{margin-left:auto;font-family:var(--font-mono);font-size:10px;background:var(--bg-alt);padding:1px 6px;border-radius:10px;color:var(--text-3)}.sb-item.active .sb-badge{background:var(--surface);color:var(--primary-ink)}.sb-footer{border-top:1px solid var(--border);padding:10px 12px;display:flex;align-items:center;gap:10px;flex-shrink:0}.sb-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:#fff;display:grid;place-items:center;font-size:11px;font-weight:600}.sb-user-meta{flex:1;min-width:0;line-height:1.2}.sb-user-name{font-size:12.5px;font-weight:600;color:var(--text)}.sb-user-role{font-size:10.5px;color:var(--text-3)}.main{display:flex;flex-direction:column;min-height:0;min-width:0;background:var(--bg)}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;flex-shrink:0}.tb-breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-3)}.tb-breadcrumb .crumb{color:var(--text-3)}.tb-breadcrumb .crumb.current{color:var(--text);font-weight:600}.tb-breadcrumb .sep{color:var(--text-4)}.tb-search{margin-left:auto;width:320px;display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md)}.tb-search input{flex:1;border:none;outline:none;background:transparent;font-size:12.5px}.tb-search input::placeholder{color:var(--text-4)}.tb-kbd{font-family:var(--font-mono);font-size:10px;color:var(--text-4);padding:1px 5px;background:var(--surface);border:1px solid var(--border);border-radius:3px}.tb-actions{display:flex;gap:4px;align-items:center}.tb-btn{width:32px;height:32px;border-radius:var(--r-md);display:grid;place-items:center;color:var(--text-2);position:relative}.tb-btn:hover{background:var(--bg-alt);color:var(--text)}.tb-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:1.5px solid var(--surface)}.page{flex:1;overflow-x:hidden;overflow-y:auto;padding:20px 24px 48px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;gap:20px}.page-title{font-size:22px;font-weight:600;letter-spacing:-.01em;margin:0}.page-sub{font-size:12.5px;color:var(--text-3);margin-top:3px}.page-actions{display:flex;gap:8px;align-items:center}.topnav{background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;height:calc(var(--topbar-h) + var(--subbar-h));gap:24px;flex-shrink:0;flex-wrap:wrap;row-gap:0}.topnav-brand{display:flex;align-items:center;gap:10px;height:var(--topbar-h)}.topnav-items{display:flex;align-items:center;gap:2px;height:var(--subbar-h);order:2;flex-basis:100%;border-top:1px solid var(--divider);margin-top:-1px;overflow-x:auto}.topnav-item{padding:8px 12px;font-size:12.5px;font-weight:500;color:var(--text-2);border-radius:var(--r-sm);white-space:nowrap}.topnav-item:hover{background:var(--bg-alt);color:var(--text)}.topnav-item.active{color:var(--primary-ink);background:var(--primary-soft)}
