:root{--bg:#0f1419;--surface:#1a2332;--surface2:#243044;--border:#2d3a4f;--text:#e8eef7;--muted:#8b9cb3;--accent:#10b981;--accent-dim:#059669;--danger:#f43f5e;--warn:#fbbf24;--radius:12px;--shadow:0 8px 32px #00000059;color:var(--text);background:var(--bg);font-family:DM Sans,system-ui,sans-serif;line-height:1.5}*,:before,:after{box-sizing:border-box}body{background:radial-gradient(ellipse 120% 80% at 50% -20%, #1e3a5f 0%, transparent 55%), var(--bg);min-height:100vh;margin:0}#app{min-height:100vh}a{color:var(--accent)}button,input,select,textarea{font:inherit}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.4rem;padding:.55rem 1rem;font-size:.875rem;font-weight:600;transition:background .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-dim));color:#042f1f}.btn-primary:hover{filter:brightness(1.08)}.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:#2c3d52}.btn-danger{color:#fda4af;background:#f43f5e33;border:1px solid #f43f5e66}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.field{flex-direction:column;gap:.35rem;margin-bottom:.85rem;display:flex}.field label{color:var(--muted);font-size:.8rem;font-weight:500}.field input,.field select,.field textarea{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:.55rem .75rem}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--accent);outline-offset:1px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.login-wrap{place-items:center;min-height:100vh;padding:1.5rem;display:grid}.login-card{width:100%;max-width:400px}.login-card h1{margin:0 0 .25rem;font-size:1.5rem}.login-card p{color:var(--muted);margin:0 0 1.25rem;font-size:.9rem}.app-layout{align-items:stretch;min-height:100vh;display:flex}.sidebar{border-right:1px solid var(--border);background:linear-gradient(#151d2b 0%,#0f1419 100%);flex-direction:column;flex-shrink:0;width:260px;padding:1.25rem 0;display:flex}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;margin-bottom:1rem;padding:0 1.25rem 1.5rem;display:flex}.sidebar-logo{background:linear-gradient(135deg, var(--accent), var(--accent-dim));color:#042f1f;border-radius:10px;place-items:center;width:42px;height:42px;font-size:.95rem;font-weight:800;display:grid}.sidebar-brand strong{letter-spacing:-.02em;font-size:1rem;display:block}.sidebar-brand small{color:var(--muted);font-size:.75rem;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:0 .75rem;display:flex}.nav-item{text-align:left;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.65rem 1rem;font-size:.875rem;font-weight:600;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{color:var(--accent);background:#10b98124;box-shadow:inset 0 0 0 1px #10b98140}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:1rem 1.25rem 0}.sidebar-user{color:var(--muted);word-break:break-all;margin-bottom:.5rem;font-size:.78rem;display:block}.main-area{flex-direction:column;flex:1;min-width:0;display:flex}.shell-main{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:1.75rem 2rem 2.5rem}.page-head{margin-bottom:1.5rem}.page-head h1{letter-spacing:-.03em;margin:0 0 .35rem;font-size:1.5rem;font-weight:700}.page-head p{color:var(--muted);max-width:52ch;margin:0;font-size:.9rem}.row-muted{opacity:.65}.badge-warn{color:#fcd34d;background:#fbbf2426}.toolbar{flex-wrap:wrap;align-items:flex-end;gap:.75rem;margin-bottom:1rem;display:flex}.toolbar .field{flex:1;min-width:140px;margin-bottom:0}.table-wrap{border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.65rem .85rem}th{background:var(--surface2);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.badge{text-transform:uppercase;border-radius:6px;padding:.15rem .45rem;font-size:.72rem;font-weight:600;display:inline-block}.badge-ok{color:#6ee7b7;background:#10b98133}.badge-off{color:var(--muted);background:#94a3b826}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal{width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 1rem;font-size:1.15rem}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.toast{background:var(--surface2);border:1px solid var(--border);box-shadow:var(--shadow);z-index:200;border-radius:10px;max-width:min(400px,100vw - 2rem);padding:.85rem 1.1rem;font-size:.875rem;position:fixed;bottom:1.25rem;right:1.25rem}.toast.err{color:#fda4af;border-color:#f43f5e80}.empty{text-align:center;color:var(--muted);padding:2rem}.muted{color:var(--muted);font-size:.85rem}@media (width<=900px){.app-layout{flex-direction:column}.sidebar{flex-flow:wrap;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem}.sidebar-brand{border:none;margin:0;padding:0 .5rem 0 0}.sidebar-nav{flex-flow:wrap;flex:1;padding:0}.nav-item{padding:.45rem .75rem;font-size:.8rem}.sidebar-footer{border:none;align-items:center;gap:.5rem;margin:0;padding:0;display:flex}.sidebar-user{text-overflow:ellipsis;white-space:nowrap;max-width:120px;margin:0;overflow:hidden}.shell-main{padding:1rem 1.1rem 2rem}}
