Forgive me some mad ramblings, please, need to brainstorm a bit:
Creatures show their TYPE (like eg "undead", "animal", "demon", "robot", "corporate lawyer"...) on mouse over.
Type is referred to by:
effects (affect only, affect never lists)
This is relevant for:
spell effects and therefore spells on weapons hit, spells from tirggers/props, spells cast by creatures or pc, spells from using items
effects lingering on the battlefield, left behind by spells like poison cloud
Creatures also show HIT BY on mouse over - this shows the PERK (e.g. holy, magic+1, obsidian, tax filing... - i might do a check whether last letter of a HIT By requirement is a number and then make the code automatically check for all PERKS with same text and a higher number at the end) a pc's weapons (incl .ammo and offhand - for the later I will add very simplified two-weapon fighting system, likely via damage adder to main hand attacks. and granting of addtional PERKS) needs to have in order to damage to a creature.
By default, this is set to "all" (eg no perk required).
PC show on mouse over the PERK(s) of their weapon.
All equipment worn by a pc writes TAGS into a pc's tag list (this includes the PERKS from weapons, shields and ammo). These TAGS are referred to by TRAITS of a pc, ie a trait only works when the PC has the rewquired TAG in its taglist. This way, traits like Axefighter (+2 to hit when wieldign an axe) or Haevy armor Expert (+2 AC in very heavy armor) become possible. This applies also for active traits that are used like spells (like an Armor Shatter trait that would reduce AC of target by 2, but would require wielding a two-handed-weapon).
Much of this is already in the code, I "just" (:lol:

) need to finish it in a few places and then integrate it into our UI (mouse over info, party screen, log, trait descriptions, item descriptions, sigh...).