:root{--bg:#0c1222;--bg-elevated:#131b2e;--bg-card:#161f36;--border:#ffffff14;--text:#e8edf7;--text-muted:#8b9bb8;--accent:#2dd4bf;--accent-dim:#2dd4bf26;--warning:#fbbf24;--danger:#f87171;--ok:#4ade80;--radius:10px;--font:"Segoe UI", system-ui, -apple-system, sans-serif;--shadow:0 8px 32px #00000059}*,:before,:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}.main a{color:var(--accent)}.main a:hover{text-decoration:underline}.app-shell{grid-template-columns:240px 1fr;min-height:100%;display:grid}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);flex-direction:column;gap:.5rem;min-height:100vh;padding:1.5rem 1rem;display:flex}.brand{letter-spacing:-.02em;color:var(--text);margin-bottom:1rem;padding:0 .75rem;font-size:1.05rem;font-weight:700}.brand-accent{color:var(--accent);font-weight:600}.nav-link{color:var(--text-muted);border-radius:8px;padding:.55rem .75rem;font-size:.92rem;text-decoration:none;transition:background .15s,color .15s;display:block}.nav-link:hover{color:var(--text);background:#ffffff0d}.nav-link.active{background:var(--accent-dim);color:var(--accent)}.main{padding:2rem 2.5rem;overflow-x:auto}.page-title{letter-spacing:-.03em;margin:0 0 .35rem;font-size:1.65rem;font-weight:650}.page-sub{color:var(--text-muted);margin:0 0 1.75rem;font-size:.95rem}.grid-stats{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.25rem}.card h3{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 .35rem;font-size:.78rem;font-weight:600}.stat-value{color:var(--text);letter-spacing:-.02em;font-size:1.75rem;font-weight:700}.stat-value.accent{color:var(--accent)}.toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.input,.select,.textarea{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:.5rem .75rem;font-family:inherit;font-size:.9rem}.textarea{resize:vertical;width:100%;min-height:80px}.input:focus,.select:focus,.textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.btn{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:.35rem;padding:.5rem 1rem;font-family:inherit;font-size:.88rem;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.btn:hover{background:#ffffff0f}.btn-primary{background:var(--accent-dim);color:var(--accent);border-color:#2dd4bf59}.btn-primary:hover{background:#2dd4bf40}.btn-ghost{background:0 0}.table-wrap{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);overflow-x:auto}table.data{border-collapse:collapse;width:100%;font-size:.88rem}table.data th,table.data td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:.65rem .85rem}table.data th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:#0003;font-size:.75rem;font-weight:600}table.data tr:last-child td{border-bottom:none}table.data tr:hover td{background:#ffffff05}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:.2rem .5rem;font-size:.72rem;font-weight:600;display:inline-block}.badge-neutral{color:var(--text-muted);background:#ffffff14}.badge-ok{color:var(--ok);background:#4ade8026}.badge-warn{color:var(--warning);background:#fbbf2426}.badge-bad{color:var(--danger);background:#f8717126}.badge-accent{background:var(--accent-dim);color:var(--accent)}.form-grid{gap:.75rem;display:grid}.form-row{gap:.35rem;display:grid}.form-row label{color:var(--text-muted);font-size:.8rem;font-weight:500}.modal-backdrop{z-index:50;background:#000000a6;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow);padding:1.5rem;overflow-y:auto}.modal h2{margin:0 0 1rem;font-size:1.15rem}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1.25rem;display:flex}.empty-hint{color:var(--text-muted);text-align:center;padding:2rem;font-size:.9rem}.footer-note{border-top:1px solid var(--border);color:var(--text-muted);margin-top:2rem;padding-top:1rem;font-size:.8rem}.sidebar-user{border-top:1px solid var(--border);margin-top:auto;padding:1rem .75rem 0}.sidebar-user-name{color:var(--text);font-size:.88rem;font-weight:600}.sidebar-user-role{color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem}.sidebar-logout{justify-content:flex-start;width:100%;padding-left:.75rem;padding-right:.75rem}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{width:100%;max-width:420px}.login-brand{margin-bottom:.5rem;padding:0;font-size:1.35rem}.login-title{margin:0 0 .5rem;font-size:1.35rem;font-weight:650}.login-hint{color:var(--text-muted);margin:0 0 1.25rem;font-size:.85rem;line-height:1.45}@media (width<=860px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap}.brand{width:100%;margin-bottom:.5rem}.sidebar-user{width:100%;margin-top:.5rem}.main{padding:1.25rem}}
