:root{--brand: #5b5bd6;--brand-2: #4f4fc6;--brand-soft: #eeedfe;--bg: #f4f6fb;--surface: #ffffff;--surface-2: #f7f8fb;--text: #0f172a;--text-2: #475569;--text-3: #94a3b8;--border: #e6e9f0;--border-2: #d8dce6;--shadow: 0 1px 2px rgba(15, 23, 42, .04);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--ok-bg: #e1f5ee;--ok-fg: #085041;--bad-bg: #fcebeb;--bad-fg: #791f1f;--warn-bg: #faeeda;--warn-fg: #633806;--info-bg: #e6f1fb;--info-fg: #0c447c;--muted-bg: #f1efe8;--muted-fg: #444441;--panel: var(--surface);--ink: var(--text);--muted: var(--text-2);--line: var(--border);--brand-ink: var(--brand-2);--ok: #16a34a;--warn: #d97706;--down: #dc2626}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.muted{color:var(--text-2)}.boot{display:grid;place-items:center;height:100vh;color:var(--text-2)}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:4px}:focus:not(:focus-visible){outline:none}.auth-screen{display:grid;place-items:center;min-height:100vh;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,#e7e7fb,var(--bg))}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:var(--shadow)}.brand{display:flex;gap:14px;align-items:center;margin-bottom:24px}.brand h1{font-size:20px;margin:0}.brand p{margin:2px 0 0;color:var(--text-2);font-size:13px}.brand-mark{width:44px;height:44px;border-radius:12px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:700;font-size:22px}.code-input{letter-spacing:8px;text-align:center;font-size:22px;font-weight:700}form{display:flex;flex-direction:column;gap:14px}label{display:flex;flex-direction:column;gap:6px;font-weight:500;font-size:13px}input,select,textarea{font:inherit;font-size:14px;padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #5b5bd626}.form-error{color:var(--bad-fg);background:var(--bad-bg);border:1px solid #f3c9c4;padding:9px 12px;border-radius:8px;font-size:13px}.form-ok{color:var(--ok-fg);background:var(--ok-bg);border:1px solid #bfe6d6;padding:9px 12px;border-radius:8px;font-size:13px}.app-shell{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{background:#14152b;color:#cdd0e5;padding:18px 14px;display:flex;flex-direction:column}.side-brand{display:flex;align-items:center;gap:10px;padding:6px 10px 18px;color:#fff;font-weight:600;font-size:15px}.side-brand .logo{width:28px;height:28px;border-radius:8px;background:var(--brand);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px}.sidebar nav{display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;color:#aab0c8;font-size:14px;cursor:pointer;margin-bottom:2px}.nav-item i{font-size:18px;color:#7b80a3}.nav-item.active{background:var(--brand);color:#fff;font-weight:500}.nav-item.active i{color:#fff}.nav-item:not(.active):hover{background:#ffffff0d;color:#fff}.nav-foot{margin-top:auto;padding:14px 10px 4px;border-top:1px solid rgba(255,255,255,.06)}.nav-user{display:flex;align-items:flex-start;gap:10px}.nav-user .av{width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#7b6bf5,#c46bd9);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}.nav-user .who{font-size:13px;color:#fff;line-height:1.35;min-width:0}.nav-user .who .name{font-weight:500;color:#fff}.nav-user .who .email{font-size:11px;color:#aab0c8;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-user .who .role-tag{display:inline-flex;align-items:center;gap:3px;font-size:10px;background:#ffffff14;color:#fff;padding:1px 7px;border-radius:999px;margin-top:4px;font-weight:500}.nav-user .who .role-tag i{font-size:10px}.logout{display:flex;align-items:center;gap:6px;margin-top:10px;background:transparent;border:1px solid rgba(255,255,255,.12);color:#cdd0e5;font-size:12px;padding:6px 10px;border-radius:6px;cursor:pointer;width:100%;justify-content:center}.logout:hover{background:#ffffff0d;color:#fff}.content{overflow:auto;min-width:0}.main{padding:24px 28px 40px;min-width:0;max-width:1320px}.page-hd{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px;flex-wrap:wrap}.page-hd h1{font-size:22px;font-weight:600;margin:0 0 4px;letter-spacing:-.01em}.page-hd p{color:var(--text-2);font-size:14px;margin:0}.page-hd .right{margin-left:auto;display:flex;gap:8px}.btn{font-family:inherit;font-size:13px;font-weight:500;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;gap:6px;line-height:1;transition:all .12s ease;white-space:nowrap}.btn i{font-size:16px}.btn:hover{border-color:var(--border-2);background:var(--surface-2)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn.primary:hover{background:var(--brand-2);border-color:var(--brand-2)}.btn.ghost{border-color:transparent}.btn.danger{color:var(--bad-fg);border-color:#f5c4b3;background:#fff}.btn.danger:hover{background:var(--bad-bg)}.btn.icon{padding:8px;width:34px;justify-content:center}.btn.sm{padding:6px 10px;font-size:12px}.btn-primary{background:var(--brand);color:#fff;border:none;padding:11px 14px;border-radius:8px;font-weight:600;cursor:pointer;font-size:14px}.btn-primary:hover{background:var(--brand-2)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-ghost{background:var(--surface);border:1px solid var(--border);padding:9px 12px;border-radius:8px;cursor:pointer;color:var(--text)}.btn-ghost:hover{background:var(--surface-2)}.btn-link{background:none;border:none;color:var(--brand);cursor:pointer;padding:0;font:inherit}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.stat-card.danger{border-left:3px solid #e24b4a}.stat-card.warn{border-left:3px solid #ef9f27}.stat-card.ok{border-left:3px solid #1d9e75}.stat-card.brand{border-left:3px solid var(--brand)}.stat-head{display:flex;align-items:center;justify-content:space-between}.stat-lab{font-size:11px;color:var(--text-2);font-weight:500;text-transform:uppercase;letter-spacing:.06em}.stat-icon{width:28px;height:28px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;color:var(--text-2)}.stat-card.danger .stat-icon{background:var(--bad-bg);color:var(--bad-fg)}.stat-card.warn .stat-icon{background:var(--warn-bg);color:var(--warn-fg)}.stat-card.ok .stat-icon{background:var(--ok-bg);color:var(--ok-fg)}.stat-card.brand .stat-icon{background:var(--brand-soft);color:var(--brand)}.stat-icon i{font-size:16px}.stat-val{font-size:26px;font-weight:600;margin-top:4px;line-height:1.1}.stat-sub{font-size:12px;color:var(--text-3);margin-top:2px}.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.search{position:relative;flex:1;min-width:240px;max-width:380px}.search i{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--text-3);pointer-events:none}.search input{width:100%;padding:9px 12px 9px 36px;border:1px solid var(--border);border-radius:8px;font-size:13px}.chip{font-size:12px;padding:7px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:inline-flex;align-items:center;gap:5px;color:var(--text-2)}.chip i{font-size:14px}.chip.active{background:var(--brand-soft);border-color:#c8c4f5;color:var(--brand);font-weight:500}.chip:hover{border-color:var(--border-2)}.right-toolbar{margin-left:auto;display:flex;gap:6px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card+.card,.stack>.card+.card{margin-top:0}.card-hd{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.card-hd h3{font-size:14px;font-weight:600;margin:0}.card-hd .meta{font-size:12px;color:var(--text-3);margin-left:auto}.card .body{padding:16px 18px}table.list{width:100%;border-collapse:collapse}table.list th,table.list td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}table.list th{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;background:var(--surface-2);white-space:nowrap}table.list th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}table.list th .sort{opacity:.5;font-size:11px;margin-left:2px}table.list th.sorted{color:var(--text)}table.list th.sorted .sort{opacity:1;color:var(--brand)}table.list tr.row{cursor:pointer;transition:background .1s ease}table.list tr.row:hover td{background:var(--surface-2)}table.list tr.row.offline td:first-child{box-shadow:inset 3px 0 #e24b4a}table.list tbody tr:last-child td{border-bottom:0}.site-cell{display:flex;flex-direction:column;gap:1px}.site-name{font-weight:500;font-size:13.5px}.site-url{font-size:11.5px;color:var(--text-3)}.num{font-variant-numeric:tabular-nums}.pill{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:500;padding:3px 9px;border-radius:999px;white-space:nowrap;line-height:1.3}.pill i{font-size:12px}.p-ok{background:var(--ok-bg);color:var(--ok-fg)}.p-bad{background:var(--bad-bg);color:var(--bad-fg)}.p-warn{background:var(--warn-bg);color:var(--warn-fg)}.p-mute{background:var(--muted-bg);color:var(--muted-fg)}.p-info{background:var(--info-bg);color:var(--info-fg)}.pill.sm{font-size:10.5px;padding:2px 7px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border);background:var(--surface-2);font-size:12.5px;color:var(--text-2)}.pages{display:flex;gap:4px}.pages .pg{min-width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;font-size:12px;color:var(--text-2);padding:0 8px}.pages .pg:hover{border-color:var(--border-2)}.pages .pg.cur{background:var(--brand);color:#fff;border-color:var(--brand);font-weight:500}.pages .pg:disabled{opacity:.4;cursor:not-allowed}.ipp{display:flex;align-items:center;gap:6px}.ipp select{font-size:12px;padding:4px 8px}.crumbs{font-size:12px;color:var(--text-3);margin-bottom:10px;display:flex;align-items:center;gap:6px}.crumbs a{color:var(--text-2)}.crumbs a:hover{color:var(--brand)}.crumbs i{font-size:11px}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-top:6px;align-items:start}.stack{display:flex;flex-direction:column;gap:16px;min-width:0}.meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 24px}.meta-row{display:flex;flex-direction:column;gap:2px;padding:2px 0}.meta-row .lab{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.meta-row .val{font-size:13.5px;color:var(--text);font-weight:500;display:flex;align-items:center;gap:6px}.meta-row .val i{font-size:14px;color:var(--text-3)}.uptime-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.uptime-cell{background:var(--surface-2);border-radius:8px;padding:10px 12px}.uptime-cell .lab{font-size:10.5px;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.uptime-cell .val{font-size:17px;font-weight:600;margin-top:3px}.uptime-cell.ok .val{color:var(--ok-fg)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.field label{font-size:12px;font-weight:500;color:var(--text-2);flex-direction:column}.field input,.field select,.field textarea{width:100%}.field textarea{resize:vertical;min-height:80px}.toggle-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-top:1px dashed var(--border);margin-top:8px}.switch{position:relative;width:36px;height:20px;background:var(--brand);border-radius:999px;cursor:pointer;flex-shrink:0;border:0}.switch:after{content:"";position:absolute;right:2px;top:2px;width:16px;height:16px;background:#fff;border-radius:999px;transition:.15s}.switch.off{background:#cbd2dc}.switch.off:after{right:18px}.toggle-row .tx{font-size:12.5px;color:var(--text-2)}.toggle-row .tx strong{color:var(--text);display:block;font-weight:500;font-size:13px}.maj-table{width:100%;border-collapse:collapse;font-size:12.5px}.maj-table th,.maj-table td{padding:9px 12px;border-bottom:1px solid var(--border);text-align:left}.maj-table th{font-size:10.5px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;background:var(--surface-2)}.maj-table tr:last-child td{border-bottom:0}.maj-table .vfrom{color:var(--text-3);font-variant-numeric:tabular-nums}.maj-table .vto{color:var(--warn-fg);font-weight:500;font-variant-numeric:tabular-nums}.maj-table .src{font-size:10.5px;color:var(--text-3);margin-right:4px;text-transform:uppercase;letter-spacing:.04em}.maj-table .actions{display:flex;gap:6px;justify-content:flex-end}table.mini{width:100%;border-collapse:collapse;font-size:12.5px}table.mini th,table.mini td{padding:9px 14px;border-bottom:1px solid var(--border);text-align:left}table.mini th{font-size:10.5px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;background:var(--surface-2);white-space:nowrap}table.mini tr:last-child td{border-bottom:0}.ts{font-variant-numeric:tabular-nums;color:var(--text-2);font-size:12px;white-space:nowrap}.who{display:flex;align-items:center;gap:6px}.who .av{width:22px;height:22px;border-radius:999px;background:var(--brand-soft);color:var(--brand);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:10.5px}.ip{font-family:ui-monospace,SFMono-Regular,monospace;font-size:12px;color:var(--text-2);background:var(--surface-2);padding:2px 6px;border-radius:4px}.setting-row{display:flex;align-items:flex-start;gap:18px;padding:14px 0;border-top:1px dashed var(--border)}.setting-row:first-child{border-top:0}.setting-row .grow{flex:1;min-width:0}.setting-row h4{margin:0;font-size:14px;font-weight:600}.setting-row p{margin:2px 0 0;font-size:12.5px;color:var(--text-2)}.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--text-2);padding:12px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.legend strong{color:var(--text);font-weight:500}.tablist{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:14px}.tab{padding:9px 14px;font-size:13px;font-weight:500;color:var(--text-2);border:0;background:transparent;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;gap:6px}.tab i{font-size:15px}.tab[aria-selected=true]{color:var(--brand);border-bottom-color:var(--brand)}.tab:hover:not([aria-selected=true]){color:var(--text)}.role-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 8px;border-radius:999px;font-weight:500}.role-admin{background:#fbeaf0;color:#993556}.role-member{background:var(--info-bg);color:var(--info-fg)}.role-viewer{background:var(--muted-bg);color:var(--muted-fg)}.avatar{border-radius:999px;background:var(--brand-soft);color:var(--brand);display:inline-flex;align-items:center;justify-content:center;font-weight:600}.page{max-width:1320px;margin:0 auto;padding:24px 28px 40px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;margin:0 0 18px}.page-head h1{margin:0 0 2px;font-size:22px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-top:16px}.panel h2{margin:0 0 14px;font-size:16px}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table-wrap table{width:100%;border-collapse:collapse}.table-wrap thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}.table-wrap tbody td{padding:12px 16px;border-bottom:1px solid var(--border)}.table-wrap tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600;background:var(--muted-bg);color:var(--muted-fg)}.badge.warn{background:var(--warn-bg);color:var(--warn-fg)}.badge.log-login{background:#e0e7ff;color:#3730a3}.badge.log-update{background:var(--warn-bg);color:var(--warn-fg)}.badge.log-plugins{background:#dbeafe;color:#1e40af}.badge.log-content{background:#dcfce7;color:#166534}.badge.log-maintenance{background:#fce7f3;color:#9d174d}.info{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px}.info-lbl{display:block;color:var(--text-3);font-size:12px;margin-bottom:4px}.info-val{font-weight:600}.status{display:inline-flex;align-items:center;font-weight:600;gap:6px}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--text-3)}.status.ok{color:var(--ok-fg)}.status.ok .dot{background:#1d9e75}.status.down{color:var(--bad-fg)}.status.down .dot{background:#e24b4a}.head-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.meta-form{display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:start}.user-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.user-form input,.user-form select{flex:1;min-width:140px}.qr{width:180px;height:180px;border:1px solid var(--border);border-radius:10px;padding:8px;background:#fff}code{background:var(--surface-2);padding:2px 6px;border-radius:5px;font-family:ui-monospace,monospace}.empty{text-align:center;color:var(--text-2);padding:32px}@media (max-width: 980px){.detail-grid{grid-template-columns:1fr}}@media (max-width: 860px){.stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 720px){.app-shell{grid-template-columns:1fr}.meta-grid,.uptime-grid{grid-template-columns:1fr 1fr}}
