:root{--bg: #f6f7f9;--surface: #ffffff;--surface-2: #f0f2f5;--border: #e3e6ea;--text: #1a1d21;--text-dim: #6b7280;--primary: #2563eb;--primary-dim: #dbe6fe;--danger: #dc2626;--success: #16a34a;--warn: #d97706;--radius: 10px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--sidebar-w: 232px}@media (prefers-color-scheme: dark){:root{--bg: #0f1216;--surface: #171b21;--surface-2: #1e242c;--border: #2a323c;--text: #e6e9ee;--text-dim: #93a0b0;--primary: #4f8cff;--primary-dim: #1c2a45;--shadow: 0 1px 3px rgba(0, 0, 0, .4)}}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}button{font-family:inherit}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:13px;font-weight:500;transition:background .12s,border-color .12s}.btn:hover{background:var(--surface-2)}.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn.primary:hover{filter:brightness(1.08)}.btn.danger{color:var(--danger);border-color:transparent}.btn.danger:hover{background:#dc26261a}.btn.sm{padding:4px 9px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.ghost{border-color:transparent;background:transparent}.btn.ghost:hover{background:var(--surface-2)}input,select{padding:8px 11px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);font-size:13px;width:100%}input:focus,select:focus{outline:2px solid var(--primary-dim);border-color:var(--primary)}label{font-size:12px;color:var(--text-dim);display:block;margin-bottom:4px;font-weight:500}.field{margin-bottom:12px}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:14px 10px;gap:2px}.brand{display:flex;align-items:center;gap:9px;padding:6px 10px 16px;font-weight:700;font-size:15px}.brand .logo{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--primary),#7c3aed);display:grid;place-items:center;color:#fff;font-size:14px}.navlink{display:flex;align-items:center;gap:10px;padding:8px 11px;border-radius:8px;color:var(--text);cursor:pointer;font-weight:500}.navlink:hover{background:var(--surface-2)}.navlink.active{background:var(--primary-dim);color:var(--primary)}.navlink .ic{width:18px;text-align:center}.sidebar .spacer{flex:1}.quota-mini{padding:10px 11px;font-size:12px;color:var(--text-dim)}.quota-bar{height:6px;border-radius:3px;background:var(--surface-2);overflow:hidden;margin:6px 0 3px}.quota-bar>div{height:100%;background:var(--primary)}.quota-bar.warn>div{background:var(--warn)}.main{overflow:auto;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:12px;padding:12px 22px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:5}.topbar .title{font-weight:600;font-size:15px}.topbar .grow{flex:1}.avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:600}.content{padding:20px 22px;flex:1}.breadcrumb{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-bottom:14px;font-size:13px}.breadcrumb .crumb{cursor:pointer;padding:3px 7px;border-radius:6px;color:var(--text-dim)}.breadcrumb .crumb:hover{background:var(--surface-2);color:var(--text)}.breadcrumb .crumb.active{color:var(--text);font-weight:600}.breadcrumb .sep{color:var(--text-dim)}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.toolbar .grow{flex:1}.node-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.node-table th{text-align:left;font-size:12px;color:var(--text-dim);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--border)}.node-table td{padding:10px 14px;border-bottom:1px solid var(--border)}.node-table tr:last-child td{border-bottom:none}.node-table tbody tr{cursor:pointer}.node-table tbody tr:hover{background:var(--surface-2)}.node-table tr.selected{background:var(--primary-dim)}.node-name{display:flex;align-items:center;gap:10px;font-weight:500}.node-icon{font-size:17px;width:22px;text-align:center}.muted{color:var(--text-dim);font-size:12px}.empty{text-align:center;padding:60px 20px;color:var(--text-dim)}.empty .big{font-size:40px;margin-bottom:10px}.panel{position:fixed;top:0;right:0;width:380px;height:100vh;background:var(--surface);border-left:1px solid var(--border);box-shadow:-4px 0 16px #00000014;z-index:20;display:flex;flex-direction:column}.panel-head{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.panel-body{overflow:auto;padding:16px 18px;flex:1}.panel-tabs{display:flex;gap:4px;padding:0 10px;border-bottom:1px solid var(--border)}.panel-tab{padding:10px 12px;cursor:pointer;font-size:13px;color:var(--text-dim);border-bottom:2px solid transparent}.panel-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.section-title{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin:18px 0 8px;font-weight:600}.list-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.list-row:last-child{border-bottom:none}.list-row .grow{flex:1;min-width:0}.chip{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;background:var(--surface-2);color:var(--text-dim)}.chip.view{background:var(--primary-dim);color:var(--primary)}.chip.edit{background:#fef3c7;color:#92400e}.chip.inherited{background:var(--surface-2)}.chip.ok{background:#dcfce7;color:#166534}.chip.warn{background:#fef3c7;color:#92400e}.chip.danger{background:#fee2e2;color:#991b1b}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:grid;place-items:center;z-index:50}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 12px 40px #0000004d;width:440px;max-width:92vw;max-height:88vh;overflow:auto}.modal-head{padding:16px 20px;border-bottom:1px solid var(--border);font-weight:600;font-size:15px}.modal-body{padding:18px 20px}.modal-foot{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:100}.toast{padding:11px 15px;border-radius:9px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);min-width:240px;font-size:13px}.toast.error{border-left:3px solid var(--danger)}.toast.success{border-left:3px solid var(--success)}.center-page{min-height:100vh;display:grid;place-items:center;padding:20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:28px;width:400px;max-width:94vw}.card h1{font-size:20px;margin:0 0 4px}.card .sub{color:var(--text-dim);margin-bottom:22px;font-size:13px}.pill-roles{display:flex;flex-wrap:wrap;gap:6px}.pill{padding:6px 11px;border-radius:20px;border:1px solid var(--border);cursor:pointer;font-size:12px}.pill.on{background:var(--primary);color:#fff;border-color:var(--primary)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.stat .k{font-size:12px;color:var(--text-dim)}.stat .v{font-size:22px;font-weight:700;margin-top:4px}.spinner{width:22px;height:22px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.row{display:flex;gap:8px;align-items:center}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:26px;text-align:center;color:var(--text-dim)}.dropzone.over{border-color:var(--primary);background:var(--primary-dim)}
