:root{--bg:#0b0d12;--panel:#121620;--panel-2:#161b27;--border:#232a3a;--text:#e6e9f0;--muted:#8a93a6;--accent:#4f7cff;--danger:#ff5a6a}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}a{color:inherit;text-decoration:none}.shell{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;height:100vh;padding:22px 14px;display:flex;position:sticky;top:0}.brand{letter-spacing:.14em;color:var(--text);padding:6px 12px 18px;font-size:18px;font-weight:700}.brand span{color:var(--accent)}.nav{flex-direction:column;gap:2px;display:flex}.nav a{color:var(--muted);border-radius:9px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav a:hover{background:var(--panel-2);color:var(--text)}.nav a .dot{background:var(--border);border-radius:50%;width:7px;height:7px}.sidebar-foot{border-top:1px solid var(--border);flex-direction:column;gap:10px;margin-top:auto;padding:14px 12px 4px;display:flex}.who-name{font-size:14px;font-weight:600}.who-role{color:var(--muted);font-size:12px}.btn-sair{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 10px;font-size:13px;transition:border-color .12s,color .12s}.btn-sair:hover{border-color:var(--danger);color:var(--danger)}.main{padding:40px 48px}.page-title{margin:0 0 6px;font-size:26px;font-weight:650}.page-sub{color:var(--muted);margin:0 0 28px;font-size:14px}.placeholder{border:1px dashed var(--border);background:var(--panel);color:var(--muted);border-radius:14px;padding:40px;font-size:14px}.login-wrap{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:14px;width:100%;max-width:380px;padding:34px 30px;display:flex}.login-brand{letter-spacing:.16em;text-align:center;font-size:22px;font-weight:700}.login-brand span{color:var(--accent)}.login-sub{color:var(--muted);text-align:center;margin:0 0 8px;font-size:13px}.field{flex-direction:column;gap:6px;display:flex}.field span{color:var(--muted);font-size:12px}input,select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:9px;outline:none;padding:10px 12px;font-size:14px}input:focus,select:focus{border-color:var(--accent)}.login-btn,.form-row button,.acts button{cursor:pointer;font-weight:600}.login-btn{background:var(--accent);color:#fff;border:none;border-radius:9px;margin-top:4px;padding:11px;font-size:14px}.login-btn:disabled{opacity:.6;cursor:default}.login-erro{color:var(--danger);background:#ff5a6a1a;border:1px solid #ff5a6a59;border-radius:9px;padding:10px 12px;font-size:13px}.card{background:var(--panel);border:1px solid var(--border);border-radius:14px}.form-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;padding:16px;display:flex}.form-row input{flex:160px}.form-row button{background:var(--accent);color:#fff;border:none;border-radius:9px;padding:10px 18px;font-size:14px}.table-card{overflow:hidden}.tbl{border-collapse:collapse;width:100%;font-size:14px}.tbl th,.tbl td{text-align:left;border-bottom:1px solid var(--border);padding:12px 16px}.tbl th{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.tbl tr:last-child td{border-bottom:none}.muted-cell{color:var(--muted);text-align:center;padding:20px 16px}.tag{border:1px solid var(--border);border-radius:99px;padding:3px 9px;font-size:12px}.tag-admin{color:var(--accent);border-color:#4f7cff66}.tag-usuario{color:var(--muted)}.acts{flex-wrap:wrap;gap:8px;display:flex}.acts button{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:7px;padding:6px 10px;font-size:12px}.acts button:hover{border-color:var(--accent)}.acts button.danger:hover{border-color:var(--danger);color:var(--danger)}
