:root{color-scheme:light;--bg: #f8fafc;--panel: #ffffff;--line: #e2e8f0;--text: #0f172a;--muted: #64748b;--accent: #0f766e;--accent-hover: #115e59;--accent-light: #ccfbf1;--danger: #b42318;--danger-hover: #991b1b;--success: #059669;--shadow: 0 1px 2px rgba(15, 23, 42, .06), 0 4px 12px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--radius: 10px;--radius-sm: 6px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-view{display:grid;place-items:center;min-height:100vh;padding:32px 20px;background:linear-gradient(180deg,#f8fafc,#f1f5f9)}.login-panel{width:min(420px,100%);padding:32px 28px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow)}.login-brand{margin-bottom:24px}.login-brand .mark{background:linear-gradient(135deg,var(--accent),#134e4a)}.login-brand p{color:var(--muted)}.login-message{min-height:28px;color:var(--danger);white-space:pre-wrap;margin:12px 0 0;font-size:13px}button,input,select,textarea{font:inherit}button{border:1px solid var(--line);background:#fff;border-radius:var(--radius-sm);padding:8px 14px;cursor:pointer;font-weight:500;transition:all .12s ease;color:var(--text)}button:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}button:active:not(:disabled){transform:translateY(1px)}button.primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}button.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}button.primary:active:not(:disabled){transform:translateY(1px)}button.danger{background:#fff;color:var(--danger);border-color:#fecaca}button.danger:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5;color:var(--danger-hover)}button.secondary{background:#fff;border-color:var(--line)}button.secondary:hover:not(:disabled){background:#f8fafc}button:disabled{cursor:not-allowed;opacity:.65}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 12px;background:#fff;color:var(--text);transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0f766e1f}textarea{min-height:130px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;line-height:1.5}select{cursor:pointer}.shell{min-height:100vh}.topbar{display:flex;justify-content:space-between;gap:16px;padding:14px 24px;background:#0f172a;color:#e2e8f0;box-shadow:0 2px 4px #0f172a26;position:relative}.topbar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(255,255,255,.08),transparent)}.brand{display:flex;align-items:center;gap:14px}.mark{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;background:var(--accent);font-weight:700;font-size:15px;color:#fff;box-shadow:0 2px 6px #0f766e59;letter-spacing:.5px}.brand h1{margin:0;font-size:17px;font-weight:600;color:#f1f5f9}.brand p{margin:1px 0 0;color:#94a3b8;font-size:12px}.session-box{display:flex;align-items:center;gap:10px;font-size:13px;color:#cbd5e1}.session-box button{background:#ffffff14;border:1px solid rgba(255,255,255,.18);color:#e2e8f0;padding:6px 12px;font-size:12px}.session-box button:hover{background:#ffffff26;border-color:#ffffff4d}.layout{display:grid;grid-template-columns:200px 1fr;min-height:calc(100vh - 68px)}.nav{padding:16px 12px;border-right:1px solid var(--line);background:#fff;display:flex;flex-direction:column;gap:4px}.nav-item{width:100%;text-align:left;padding:9px 14px;margin:0;border-radius:8px;border:1px solid transparent;background:transparent;font-size:13.5px;font-weight:500;color:#475569}.nav-item:hover{background:#f1f5f9;color:var(--text)}.nav-item.active{background:var(--accent-light);color:var(--accent);font-weight:600;border-color:transparent}.nav-item.active:hover{background:#b4f0e3}.content{min-width:0;padding:20px 22px}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px}.toolbar button{font-size:13px;padding:6px 12px}.danger{color:var(--danger)}.metric-grid,.split{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.split{grid-template-columns:minmax(260px,370px) minmax(0,1fr)}.metric{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.metric:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(to right,var(--accent),#14b8a6)}.metric span{display:block;color:var(--muted);font-size:12px;font-weight:500;letter-spacing:.3px}.metric strong{display:block;margin-top:6px;font-size:26px;font-weight:600;line-height:1.1;color:var(--text)}.health-value{display:flex!important;align-items:center;gap:10px}.health-button{margin-top:6px;padding:0;border:0;background:transparent;color:var(--text);font-size:26px;font-weight:600;line-height:1.1}.health-button:hover:not(:disabled){background:transparent;color:var(--accent)}.health-metric{overflow:visible;z-index:2}.health-popover{position:absolute;top:calc(100% - 8px);left:18px;width:min(360px,calc(100vw - 48px));padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow);z-index:20}.health-detail-row{display:grid;grid-template-columns:1fr auto;gap:6px 12px;padding:8px 0;border-bottom:1px solid #f1f5f9}.health-detail-row:last-child{border-bottom:0}.health-detail-name{color:var(--text)!important;font-weight:600!important}.health-detail-status{color:var(--success)!important;font-size:12px;font-weight:600}.health-detail-status.error{color:var(--danger)!important}.health-detail-row p{grid-column:1 / -1;margin:0;color:var(--muted);font-size:12px;line-height:1.5;white-space:normal;word-break:break-word}.health-light{display:inline-block;width:14px;height:14px;border-radius:50%;flex-shrink:0;position:relative}.health-light.healthy{background:#22c55e;box-shadow:0 0 8px 2px #22c55e73;animation:health-pulse-green 2s ease-in-out infinite}.health-light.degraded{background:#f59e0b;box-shadow:0 0 8px 2px #f59e0b73;animation:health-pulse-amber 1.2s ease-in-out infinite}.health-light.unknown{background:#94a3b8;box-shadow:0 0 4px 1px #94a3b84d}@keyframes health-pulse-green{0%,to{box-shadow:0 0 8px 2px #22c55e73}50%{box-shadow:0 0 14px 5px #22c55e40}}@keyframes health-pulse-amber{0%,to{box-shadow:0 0 8px 2px #f59e0b80}50%{box-shadow:0 0 14px 5px #f59e0b33}}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);margin-top:14px}.panel:first-child{margin-top:0}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #f1f5f9}.panel-title h2{margin:0;font-size:15px;font-weight:600;color:var(--text)}.list-item{display:block;width:100%;text-align:left;padding:10px 14px;margin-bottom:6px;border-radius:8px;border:1px solid var(--line);background:#fff;font-size:13.5px}.list-item:hover{background:#f8fafc}.list-item.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:600}.list-item span{display:block;margin-top:3px;color:var(--muted);font-size:12px}.list-item.active span{color:#0f766e}.checkbox-list,.form-grid,.param-form{display:grid;gap:9px}.role-create{margin-bottom:10px}.permission-group{display:grid;gap:8px;padding:10px 0 14px;border-bottom:1px solid var(--line)}.permission-group h3{margin:0;font-size:13px;font-weight:600}.checkbox-list label{display:grid;grid-template-columns:22px 1fr;align-items:center;gap:9px;padding:4px 0}.checkbox-list small,.interface-item span,.param-row span{color:var(--muted);font-size:12px}.interface-tree{display:grid;gap:2px;margin:0;padding-left:0;list-style:none;max-height:520px;overflow:auto}.tree-search{margin:4px 0 8px}.tree-search input{font-size:13px;padding:6px 10px}.interface-tree .interface-tree{margin-top:3px;padding-left:18px;border-left:1px solid #e2e8f0}.interface-tree summary{cursor:pointer;color:var(--text);font-weight:600;font-size:13px;padding:4px 6px;border-radius:6px}.interface-tree summary:hover{background:#f1f5f9}.checkbox-list .category-checkbox,.category-checkbox{display:inline-flex;align-items:center;cursor:pointer}.category-checkbox input{width:auto;cursor:pointer;margin-right:6px}.tree-interface{width:100%;text-align:left;padding:7px 10px;border-radius:7px;border:1px solid transparent;background:#fff}.tree-interface:hover{background:#f8fafc}.tree-interface strong{display:block;font-size:13px}.tree-interface span{color:var(--muted);font-size:12px;display:block}.tree-interface.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.tree-interface.permission-leaf{display:grid;grid-template-columns:22px minmax(0,1fr);align-items:flex-start;padding:6px 8px;gap:8px}.tree-interface.permission-leaf input{width:auto;margin-top:3px}.tree-interface.readonly-leaf{grid-template-columns:minmax(0,1fr)}.readonly-tree .interface-tree{max-height:360px}.tree-interface-label{display:flex;align-items:center;gap:8px}.limit-grid{display:grid;grid-template-columns:repeat(4,minmax(110px,1fr));gap:10px}.key-inline,.switch{display:flex;align-items:center;gap:8px}.switch input{width:auto;margin:0}.test-layout{display:grid;grid-template-columns:250px minmax(320px,1fr) minmax(340px,1.05fr);gap:14px}.test-layout .panel:last-child{grid-column:1 / -1}.interface-item{width:100%;text-align:left;padding:8px 10px}.interface-item strong,.param-row strong{display:block;font-size:13.5px}.param-row{display:grid;grid-template-columns:118px minmax(160px,1fr);gap:10px;align-items:flex-start}.field-list{display:grid;max-height:480px;overflow:auto;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff}.field-row{display:grid;grid-template-columns:26px minmax(118px,1fr) 68px minmax(150px,1.3fr);gap:8px;align-items:center;padding:8px 10px;border-bottom:1px solid var(--line);font-size:12.5px}.field-row:last-child{border-bottom:none}.field-row:nth-child(2n){background:#f8fafc}.field-row:hover{background:#f1f5f9}.field-row input{width:auto}.table{overflow:auto;border-radius:var(--radius-sm);border:1px solid var(--line)}table{width:100%;border-collapse:collapse;font-size:13px;background:#fff}th,td{border-bottom:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}th{color:var(--muted);font-weight:600;background:#f8fafc;font-size:12.5px;text-transform:none;letter-spacing:.2px}tr:last-child td{border-bottom:none}tbody tr:hover{background:#f8fafc}.pagination-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:10px;color:var(--muted);font-size:13px}.pagination-bar label{display:inline-flex;align-items:center;gap:6px}.pagination-bar select{width:auto;min-width:72px;padding:5px 8px}.pagination-bar button{padding:6px 11px;font-size:12px}.field{display:block;margin-bottom:11px}.field span{display:block;margin-bottom:5px;color:var(--muted);font-size:12.5px;font-weight:500}.message{min-height:200px;max-height:420px;overflow:auto;white-space:pre-wrap;border:1px solid #1e2937;border-radius:8px;padding:14px;background:#0f172a;color:#e0e7ff;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:12.5px;line-height:1.5}.empty{color:var(--muted);padding:16px 6px;font-size:13px}.tab-bar{display:flex;gap:2px;border-bottom:2px solid var(--line);padding-bottom:1px}.tab-item{border:none;border-radius:6px 6px 0 0;background:transparent;padding:9px 16px;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px;font-size:13.5px}.tab-item:hover{color:#475569}.tab-item.active{color:var(--accent);font-weight:600;border-bottom-color:var(--accent)}.tab-bar.compact{margin-bottom:12px}.tab-bar.compact .tab-item{padding:7px 13px;font-size:13px}.role-tab{display:grid;gap:14px}.feature-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}.profile-list{display:grid;gap:8px;margin:0}.profile-list div{display:grid;grid-template-columns:110px minmax(0,1fr);gap:12px;padding:8px 0;border-bottom:1px solid #f1f5f9}.profile-list div:last-child{border-bottom:0}.profile-list dt{color:var(--muted);font-size:12.5px;font-weight:500}.profile-list dd{margin:0;color:var(--text);font-size:13.5px;font-weight:500;word-break:break-word}.profile-list.compact div{grid-template-columns:80px minmax(0,1fr);padding:6px 0}.profile-wide{grid-column:1 / -1}.profile-permission-grid{display:grid;grid-template-columns:1fr 1fr minmax(220px,.6fr);gap:18px}.profile-permission-grid h3{margin:0 0 9px;font-size:13px;font-weight:600}.tag-list{display:flex;flex-wrap:wrap;gap:7px}.tag{display:inline-flex;align-items:center;max-width:100%;min-height:26px;padding:3px 9px;border-radius:999px;background:#f1f5f9;border:1px solid var(--line);color:#334155;font-size:12px;word-break:break-word}.muted-text{color:var(--muted);font-size:13px}.form-message{min-height:20px;margin:10px 0 0;color:var(--success);font-size:13px}.sync-form{display:flex;align-items:flex-end;gap:12px;margin-bottom:14px}.sync-form .field{margin-bottom:0;min-width:200px}.sync-result{padding:12px 14px;border-radius:8px;background:#ecfdf5;color:#065f46;font-size:13px;margin-bottom:14px;border:1px solid #a7f3d0}.sync-result.error{background:#fef2f2;color:var(--danger);border-color:#fecaca}.diff-panel{margin-top:12px}.diff-section{margin-bottom:16px}.diff-title{margin:0 0 8px;font-size:14px;font-weight:600}.diff-title.added,.diff-title.removed{color:var(--danger)}.diff-title.unchanged{color:var(--muted);cursor:pointer;font-size:13px}.diff-warning{margin:0 0 8px;font-size:12px;color:var(--danger)}.diff-list{list-style:none;margin:0;padding:0;display:grid;gap:4px}.diff-item{display:flex;align-items:center;gap:8px;padding:6px 11px;border-radius:7px;font-size:13px}.diff-item.added{background:#ecfdf5}.diff-item.removed{background:#fef2f2;text-decoration:line-through}.diff-item.unchanged{background:#f8fafc}.diff-item strong{font-weight:600}.diff-item small{color:var(--muted)}.diff-badge{display:inline-flex;align-items:center;padding:1px 7px;border-radius:10px;font-size:11px;font-weight:600;line-height:1.6}.diff-badge.added,.diff-badge.removed{background:#fee2e2;color:#991b1b}.diff-badge.unchanged{background:#d1fae5;color:#065f46}.progress-bar{width:100%;height:4px;background:var(--line);border-radius:999px;overflow:hidden;margin-bottom:14px}.progress-bar-indeterminate{width:32%;height:100%;background:var(--accent);border-radius:999px;animation:indeterminate 1.15s ease-in-out infinite}@keyframes indeterminate{0%{transform:translate(-110%)}to{transform:translate(340%)}}.diff-summary{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.diff-warning-inline{font-size:12px;color:var(--danger)}.tree-status-added{background:#fef2f2!important;border-color:#fecaca!important}.tree-status-removed{background:#fef2f2!important;opacity:.75}.tree-status-unchanged{background:#ecfdf5!important;border-color:#a7f3d0!important}.tree-status-removed strong{text-decoration:line-through}.view{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:.6}to{opacity:1}}@media(max-width:960px){.test-layout{grid-template-columns:1fr}.test-layout .panel:last-child{grid-column:auto}.split,.metric-grid{grid-template-columns:1fr}.profile-wide{grid-column:auto}.profile-permission-grid{grid-template-columns:1fr}.limit-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:860px){.topbar{padding:12px 16px}.layout{grid-template-columns:1fr}.nav{display:flex;flex-direction:row;gap:4px;overflow-x:auto;border-right:0;border-bottom:1px solid var(--line);padding:10px 8px;background:#fff}.nav-item{min-width:max-content;margin:0;padding:7px 13px}.content{padding:16px}.param-row,.field-row,.checkbox-list label{grid-template-columns:1fr}.topbar{display:grid;gap:10px}.brand{gap:10px}}
