:root{--bg: #f3f5fa;--surface: #ffffff;--surface-2: #f7f9fc;--text: #1c2434;--text-2: #5b6478;--muted: #98a2b8;--border: #e6e9f2;--primary: #4f46e5;--primary-700: #4338ca;--primary-50: #eef0fe;--ok: #16a34a;--ok-bg: #e9f7ef;--warn: #d97706;--warn-bg: #fdf3e6;--danger: #dc2626;--danger-bg: #fdecec;--info: #0ea5e9;--info-bg: #e7f6fe;--shadow: 0 1px 2px rgba(16, 24, 40, .05), 0 1px 3px rgba(16, 24, 40, .06);--shadow-md: 0 4px 16px rgba(16, 24, 40, .08);--radius: 12px;--sidebar-w: 244px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}svg{display:block}.shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:.65rem;padding:1.1rem 1.25rem;border-bottom:1px solid var(--border)}.brand-mark{width:34px;height:34px;border-radius:9px;flex:0 0 34px;background:linear-gradient(135deg,var(--primary),#7c6cf2);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px}.brand-name{font-weight:750;font-size:1.02rem;line-height:1.1}.brand-name span{color:var(--primary)}.brand-sub{font-size:.68rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}.nav{padding:.75rem .6rem;display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}.nav-section{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:1rem .65rem .35rem}.nav-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:9px;color:var(--text-2);font-weight:550;font-size:.92rem;cursor:pointer;position:relative}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-50);color:var(--primary-700);font-weight:650}.nav-item.active:before{content:"";position:absolute;left:-6px;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--primary)}.nav-item svg{width:18px;height:18px}.nav-item.disabled{color:var(--muted);cursor:default}.nav-item.disabled:hover{background:transparent}.soon{margin-left:auto;font-size:.6rem;background:var(--surface-2);color:var(--muted);border:1px solid var(--border);padding:.1rem .35rem;border-radius:6px;letter-spacing:.03em}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:62px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1rem;padding:0 1.5rem;position:sticky;top:0;z-index:5}.topbar-title{font-size:1.12rem;font-weight:700}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:.9rem}.search{display:flex;align-items:center;gap:.5rem;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:.45rem .7rem;width:240px;color:var(--muted)}.search input{border:0;background:transparent;outline:none;width:100%;color:var(--text);font-size:.9rem;padding:0}.icon-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--border);background:var(--surface);display:grid;place-items:center;color:var(--text-2);cursor:pointer}.icon-btn:hover{background:var(--surface-2)}.user-chip{display:flex;align-items:center;gap:.55rem;padding-left:.4rem}.avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.85rem}.user-meta{line-height:1.15}.user-meta b{font-size:.85rem;font-weight:650}.user-meta small{display:block;color:var(--muted);font-size:.72rem}.content{padding:1.5rem;max-width:1180px;width:100%;margin:0 auto}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem;gap:1rem;flex-wrap:wrap}.page-head h1{font-size:1.35rem;margin:0}.page-head p{margin:.2rem 0 0;color:var(--muted);font-size:.9rem}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.25rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.5rem}.kpi-top{display:flex;align-items:center;justify-content:space-between}.kpi-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center}.kpi-icon svg{width:20px;height:20px}.kpi-value{font-size:1.9rem;font-weight:760;letter-spacing:-.02em}.kpi-label{color:var(--muted);font-size:.85rem;font-weight:550}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;border-bottom:1px solid var(--border)}.panel-title{font-weight:680;font-size:1rem}.panel-body{padding:1.2rem}.grid-2{display:grid;grid-template-columns:360px 1fr;gap:1rem;margin-bottom:1.25rem}.donut-wrap{display:flex;align-items:center;gap:1.2rem}.legend{display:flex;flex-direction:column;gap:.55rem}.legend-item{display:flex;align-items:center;gap:.55rem;font-size:.88rem;color:var(--text-2)}.legend-item .dot{width:10px;height:10px;border-radius:3px;flex:0 0 10px}.legend-item b{margin-left:auto;color:var(--text)}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th{text-align:left;padding:.7rem 1.2rem;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border-bottom:1px solid var(--border)}.table td{padding:.8rem 1.2rem;border-bottom:1px solid var(--border);font-size:.9rem}.table tbody tr:last-child td{border-bottom:0}.table tbody tr:hover{background:var(--surface-2)}.cell-strong{font-weight:600}.cell-mono{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.82rem;color:var(--text-2)}.empty{text-align:center;color:var(--muted);padding:2.5rem 1rem}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.22rem .6rem;border-radius:999px;font-size:.74rem;font-weight:650}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge.active{color:var(--ok);background:var(--ok-bg)}.badge.pending{color:var(--warn);background:var(--warn-bg)}.badge.offline{color:var(--danger);background:var(--danger-bg)}.badge.retired{color:var(--text-2);background:var(--surface-2)}.btn{display:inline-flex;align-items:center;gap:.45rem;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:9px;padding:.55rem .9rem;font-weight:600;font-size:.9rem;cursor:pointer}.btn:hover{background:var(--surface-2)}.btn svg{width:16px;height:16px}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-700)}.btn:disabled{opacity:.6;cursor:default}.input{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:9px;padding:.55rem .7rem;font-size:.9rem;width:100%}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-50)}.toolbar{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;flex-wrap:wrap}.toolbar .search{width:280px}.count-pill{font-size:.78rem;color:var(--text-2);background:var(--surface);border:1px solid var(--border);padding:.3rem .6rem;border-radius:999px}.spacer{flex:1}.error{background:var(--danger-bg);color:var(--danger);border:1px solid #f6c9c9;padding:.6rem .8rem;border-radius:9px;margin-bottom:1rem;font-size:.88rem}.muted{color:var(--muted)}.login-page{min-height:100vh;display:grid;place-items:center;padding:1.5rem;background:radial-gradient(1200px 600px at 50% -10%,#e9ecff 0%,var(--bg) 55%)}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-md);padding:2rem}.login-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1.5rem}.login-card h1{font-size:1.25rem;margin:0 0 .25rem}.login-card .sub{color:var(--muted);font-size:.9rem;margin-bottom:1.4rem}.field{margin-bottom:1rem}.field label{display:block;font-size:.82rem;font-weight:600;color:var(--text-2);margin-bottom:.35rem}.login-card .btn-primary{width:100%;justify-content:center;padding:.7rem;margin-top:.3rem}.switch{position:relative;display:inline-block;width:40px;height:22px;flex:0 0 40px}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:#cfd5e3;border-radius:99px;transition:.18s}.switch .slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.18s;box-shadow:0 1px 2px #00000040}.switch input:checked+.slider{background:var(--primary)}.switch input:checked+.slider:before{transform:translate(18px)}.toggle-row{display:flex;align-items:center;gap:.8rem;padding:.55rem 0}.toggle-row .tr-main{flex:1;min-width:0}.toggle-row .tr-label{font-weight:600;font-size:.9rem}.toggle-row .tr-hint{font-size:.8rem;color:var(--muted)}.toggle-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1.6rem}.toggle-grid .toggle-row{border-bottom:1px solid var(--border)}.slider-row{padding:.2rem 0 .8rem}.slider-row label{font-size:.82rem;font-weight:600;color:var(--text-2)}.slider-row input[type=range]{width:100%;max-width:380px;display:block;margin-top:.45rem;accent-color:var(--primary)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.5rem;cursor:pointer;transition:border-color .15s,box-shadow .15s}.profile-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.profile-card h3{margin:0;font-size:1.02rem}.profile-card .pc-desc{color:var(--muted);font-size:.85rem;min-height:1.2em}.profile-card .pc-meta{display:flex;gap:.5rem;margin-top:.3rem;flex-wrap:wrap}.chip{font-size:.74rem;font-weight:650;padding:.2rem .55rem;border-radius:999px;background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}.chip.accent{background:var(--primary-50);color:var(--primary-700);border-color:transparent}@media (max-width: 900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.sidebar{position:fixed;transform:translate(-100%);z-index:20;transition:transform .2s}.sidebar.open{transform:none}}
