:root{--bg:#f4f3f9;--surface:#fff;--border:#ececf2;--border-strong:#d8d8e2;--text:#1f2024;--text-muted:#6e6e7a;--text-soft:#9396a1;--primary:#6c3fd7;--primary-hover:#5a32bd;--primary-soft:#ece6fa;--primary-soft-hover:#ddd2f5;--selected:#f3eefc;--danger:#d73a3a;--danger-soft:#fde6e6;--warning:#f4a623;--shadow:0 10px 24px #2319461f;--radius:8px}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--text);margin:0;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.4}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none;padding:0}input{font:inherit;color:inherit}.app{background:var(--bg);grid-template-columns:64px 1fr 320px 64px;height:100vh;display:grid}.left-nav{background:0 0;flex-direction:column;align-items:center;gap:18px;padding:16px 0;display:flex}.left-nav .plus-btn{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.left-nav .nav-item{width:32px;height:32px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;display:flex}.left-nav .nav-item.active{color:var(--primary);background:#e7e3f4}.left-nav .nav-spacer{flex:1}.left-nav .collapse{color:var(--text-soft);justify-content:center;align-items:center;width:32px;height:32px;display:flex}.main-col{flex-direction:column;min-width:0;padding:16px 12px 16px 0;display:flex;overflow-y:auto}.page{background:var(--surface);border-radius:12px;flex-direction:column;flex:1;min-height:100%;display:flex;overflow:hidden}.alerts-col{background:var(--surface);border-left:1px solid var(--border);padding:16px;position:relative;overflow-y:auto}.alerts-col .alerts-head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.alerts-col h3{margin:0;font-size:18px;font-weight:600}.alerts-col .alerts-head-icons{color:var(--text-muted);gap:12px;display:flex}.alerts-filter{gap:8px;margin-bottom:16px;display:flex}.pill{background:var(--danger-soft);color:var(--danger);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:500}.dropdown-pill{color:var(--text);background:#f1f1f5;border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;display:inline-flex}.alert{grid-template-columns:16px 1fr;align-items:start;gap:10px;padding:8px 0;display:grid}.alert .dot{background:var(--danger);border-radius:50%;width:10px;height:10px;margin-top:6px}.alert .badge{background:var(--warning);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;margin-top:2px;font-size:11px;font-weight:600;display:flex}.alert .title{font-size:13px;font-weight:500}.alert .sub{color:var(--text-muted);font-size:12px}.right-col{flex-direction:column;align-items:center;gap:16px;padding:16px 0;display:flex}.avatar{background:#d6d6e0 url(https://i.pravatar.cc/72?img=12) 50%/cover;border-radius:50%;width:36px;height:36px}.right-col .icon-btn{width:32px;height:32px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;display:flex}.page-header{padding:20px 24px 12px}.page-header-top{justify-content:space-between;align-items:center;gap:12px;min-height:32px;display:flex}.page-header-top .left{color:var(--text-muted);align-items:center;gap:8px;display:flex}.back-btn{width:32px;height:32px;color:var(--text);border-radius:6px;justify-content:center;align-items:center;display:flex}.back-btn:hover{background:#f1f1f5}.breadcrumb{color:var(--text-muted)}.breadcrumb .crumb{cursor:pointer}.breadcrumb .crumb:hover{color:var(--text)}.page-header-actions{align-items:center;gap:8px;display:flex}.btn{background:var(--primary-soft);color:var(--primary);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:500}.btn:hover{background:var(--primary-soft-hover)}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-hover)}.btn.primary:disabled,.btn.primary[disabled]{cursor:not-allowed;background:#c1b5e6}.icon-btn-ghost{width:32px;height:32px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;display:flex}.icon-btn-ghost:hover{color:var(--text);background:#f1f1f5}.page-title{color:var(--text);align-items:center;gap:10px;margin:16px 0 12px;font-size:22px;font-weight:600;display:flex}.page-title .title-icon{color:var(--text-muted)}.tag-row{flex-wrap:wrap;align-items:center;gap:6px;min-height:28px;display:flex;position:relative}.chip{color:var(--text);cursor:pointer;background:#f1f1f5;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;display:inline-flex}.chip:hover{background:#e7e7ee}.chip.issues{color:#c43d3d;background:#fce4e4}.chip.issues:hover{background:#f7d0d0}.chip.no-tags{color:var(--text-muted);background:0 0;align-items:center;gap:6px;padding:4px 6px;display:inline-flex}.chip.no-tags:hover{background:#f1f1f5}.add-tag-btn{width:24px;height:24px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;display:flex}.add-tag-btn:hover{color:var(--text);background:#f1f1f5}.popover-anchor{display:inline-flex;position:relative}.popover{width:280px;box-shadow:var(--shadow);border:1px solid var(--border);z-index:30;background:#fff;border-radius:10px;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden}.popover .search-row{border-bottom:1px solid var(--border);padding:10px 12px}.popover .search-row input{width:100%;color:var(--text);background:0 0;border:none;outline:none;font-size:14px}.popover .search-row input::placeholder{color:var(--text-soft)}.popover .tag-list{max-height:280px;margin:0;padding:6px 0;list-style:none;overflow-y:auto}.popover .tag-list .empty{color:var(--text-muted);text-align:left;padding:14px 16px;font-size:13px}.popover-row{cursor:pointer;border-radius:6px;grid-template-columns:20px 1fr auto;align-items:center;gap:10px;margin:0 6px;padding:8px 12px;display:grid}.popover-row:hover{background:#f5f3fb}.popover-row.selected{background:var(--selected)}.popover-row .row-icon{color:var(--text-muted);align-items:center;display:flex}.popover-row .row-name{color:var(--text);text-align:left;text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.popover-row .row-actions{color:var(--text-muted);align-items:center;gap:6px;display:flex}.popover-row .pen{border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.popover-row .pen:hover{color:var(--primary);background:#ece6fa}.popover-row .check{color:var(--text-muted);align-items:center;display:flex}.popover-footer{border-top:1px solid var(--border);padding:6px}.popover-footer .new-tag{width:100%;color:var(--text);border-radius:6px;align-items:center;gap:10px;padding:8px 10px;font-size:14px;display:flex}.popover-footer .new-tag:hover{background:#f5f3fb}.popover-form{flex-direction:column;gap:12px;padding:12px;display:flex}.popover-form .form-title{color:var(--text);font-size:13px;font-weight:500}.popover-form .input-wrap{border-bottom:1px solid var(--border-strong);padding-bottom:6px}.popover-form input{width:100%;color:var(--text);background:0 0;border:none;outline:none;font-size:14px}.popover-form .error{color:var(--danger);margin-top:2px;font-size:12px}.popover-form .actions{justify-content:flex-end;gap:8px;display:flex}.popover-row.renaming{grid-template-columns:1fr;padding:10px}.toolbar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);grid-template-columns:40px 1fr auto auto;align-items:center;gap:12px;padding:12px 24px;display:grid}.toolbar .checkbox{border:1px solid var(--border-strong);border-radius:4px;width:18px;height:18px}.toolbar .total{color:var(--text);font-size:14px}.toolbar .sort-btn{color:var(--text);background:#f1f1f5;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:inline-flex}.toolbar .filter-input{border:1px solid var(--border);background:#fff;border-radius:6px;align-items:center;gap:8px;min-width:260px;padding:6px 10px;display:flex}.toolbar .filter-input input{border:none;outline:none;flex:1}.row-list{margin:0;padding:0;list-style:none}.list-row{border-bottom:1px solid var(--border);cursor:pointer;grid-template-columns:40px 1fr auto 40px;align-items:center;gap:12px;padding:12px 24px;display:grid}.list-row:hover{background:#faf9fd}.list-row .checkbox{border:1px solid var(--border-strong);border-radius:4px;width:18px;height:18px}.list-row .name{color:var(--text);align-items:center;gap:10px;font-size:14px;display:flex}.list-row .meta{gap:6px;display:flex}.meta-chip{color:var(--text);background:#f4f3f9;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;display:inline-flex}.meta-chip svg{color:var(--text-muted)}.meta-unassigned{color:var(--text-muted);font-size:13px}.row-actions-cell{justify-content:flex-end;display:flex;position:relative}.kebab{width:28px;height:28px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;display:flex}.kebab:hover{color:var(--text);background:#f1f1f5}.menu{border:1px solid var(--border);box-shadow:var(--shadow);z-index:20;background:#fff;border-radius:8px;min-width:140px;padding:4px;position:absolute;top:calc(100% + 4px);right:0}.menu button{text-align:left;border-radius:6px;width:100%;padding:8px 10px;font-size:13px;display:block}.menu button:hover{background:#f5f3fb}.server-grid{background:var(--border);border-top:1px solid var(--border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.server-card{background:var(--surface);min-height:120px;padding:18px 20px 22px}.server-card h4{color:var(--text);justify-content:space-between;align-items:center;margin:0 0 14px;font-size:14px;font-weight:500;display:flex}.server-card .arrow{color:var(--text-soft)}.server-card .big{font-size:18px;font-weight:500}.server-card .issues{color:#d73a3a;align-items:center;gap:8px;margin-bottom:14px;font-size:22px;font-weight:600;display:flex}.server-card .mini-chips{gap:6px;display:flex}.server-card .mini-chip{color:#c43d3d;background:#fce4e4;border-radius:6px;padding:3px 8px;font-size:12px}.server-card .muted{color:var(--text-muted)}.wp-row{background:var(--surface);border-top:1px solid var(--border);padding:18px 20px 22px}.wp-row .risk{margin-bottom:12px;font-size:22px;font-weight:600}.wp-row .risk small{color:var(--text-muted);font-size:14px;font-weight:400}.tag-pill-row{align-items:center;display:flex}.toast{color:#fff;z-index:100;background:#2b2b35;border-radius:8px;align-items:center;gap:10px;padding:10px 12px 10px 16px;font-size:13px;display:flex;position:fixed;bottom:32px;left:50%;transform:translate(-50%);box-shadow:0 6px 20px #0003}.toast .undo{color:#b8a7f0;border-radius:6px;padding:4px 8px;font-weight:500}.toast .undo:hover{background:#ffffff14}.toast .close{color:#ffffffb3;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.toast .close:hover{color:#fff;background:#ffffff14}
