diff --git a/code/datums/diseases/advance/symptoms/disfiguration.dm b/code/datums/diseases/advance/symptoms/disfiguration.dm
new file mode 100644
index 00000000000..4a4b704dc0e
--- /dev/null
+++ b/code/datums/diseases/advance/symptoms/disfiguration.dm
@@ -0,0 +1,50 @@
+/*
+//////////////////////////////////////
+Disfiguration
+
+ Hidden.
+ No change to resistance.
+ Increases stage speed.
+ Slightly increases transmittability.
+ Critical Level.
+
+BONUS
+ Adds disfiguration trait making the mob appear as "Unknown" to others.
+
+//////////////////////////////////////
+*/
+
+/datum/symptom/disfiguration
+
+ name = "Disfiguration"
+ desc = "The virus liquefies facial muscles, disfiguring the host."
+ stealth = 2
+ resistance = 0
+ stage_speed = 3
+ transmittable = 1
+ level = 5
+ severity = 1
+ symptom_delay_min = 25
+ symptom_delay_max = 75
+
+/datum/symptom/disfiguration/Activate(datum/disease/advance/A)
+ . = ..()
+ if(!.)
+ return
+ var/mob/living/M = A.affected_mob
+ if (HAS_TRAIT(M, TRAIT_DISFIGURED))
+ return
+ switch(A.stage)
+ if(5)
+ ADD_TRAIT(M, TRAIT_DISFIGURED, DISEASE_TRAIT)
+ M.visible_message("[M]'s face appears to cave in!", "You feel your face crumple and cave in!")
+ else
+ M.visible_message("[M]'s face begins to contort...", "Your face feels wet and malleable...")
+
+
+/datum/symptom/disfiguration/End(datum/disease/advance/A)
+ . = ..()
+ if(!.)
+ return
+ if(A.affected_mob)
+ REMOVE_TRAIT(A.affected_mob, TRAIT_DISFIGURED, DISEASE_TRAIT)
\ No newline at end of file
diff --git a/code/datums/diseases/advance/symptoms/skin.dm b/code/datums/diseases/advance/symptoms/skin.dm
index 300eecc80ed..d7a457aec1a 100644
--- a/code/datums/diseases/advance/symptoms/skin.dm
+++ b/code/datums/diseases/advance/symptoms/skin.dm
@@ -1,68 +1,22 @@
/*
//////////////////////////////////////
-Vitiligo
+Polyvitiligo
- Hidden.
- No change to resistance.
- Increases stage speed.
- Slightly increases transmittability.
- Critical Level.
-
-BONUS
- Makes the mob lose skin pigmentation.
-
-//////////////////////////////////////
-*/
-
-/datum/symptom/vitiligo
-
- name = "Vitiligo"
- desc = "The virus destroys skin pigment cells, causing rapid loss of pigmentation in the host."
- stealth = 2
- resistance = 0
- stage_speed = 3
- transmittable = 1
- level = 5
- severity = 1
- symptom_delay_min = 25
- symptom_delay_max = 75
-
-/datum/symptom/vitiligo/Activate(datum/disease/advance/A)
- if(!..())
- return
- var/mob/living/M = A.affected_mob
- if(ishuman(M))
- var/mob/living/carbon/human/H = M
- if(H.skin_tone == "albino")
- return
- switch(A.stage)
- if(5)
- H.skin_tone = "albino"
- H.update_body(0)
- else
- H.visible_message("[H] looks a bit pale...", "Your skin suddenly appears lighter...")
-
-
-/*
-//////////////////////////////////////
-Revitiligo
-
- Slightly noticable.
+ Noticeable.
Increases resistance.
Increases stage speed slightly.
Increases transmission.
Critical Level.
BONUS
- Makes the mob gain skin pigmentation.
+ Makes the mob gain a random crayon powder colorful reagent.
//////////////////////////////////////
*/
-/datum/symptom/revitiligo
-
- name = "Revitiligo"
- desc = "The virus causes increased production of skin pigment cells, making the host's skin grow darker over time."
+/datum/symptom/polyvitiligo
+ name = "Polyvitiligo"
+ desc = "The virus replaces the melanin in the skin with reactive pigment."
stealth = -1
resistance = 3
stage_speed = 1
@@ -72,17 +26,16 @@ BONUS
symptom_delay_min = 7
symptom_delay_max = 14
-/datum/symptom/revitiligo/Activate(datum/disease/advance/A)
+/datum/symptom/polyvitiligo/Activate(datum/disease/advance/A)
if(!..())
return
var/mob/living/M = A.affected_mob
- if(ishuman(M))
- var/mob/living/carbon/human/H = M
- if(H.skin_tone == "african2")
- return
- switch(A.stage)
- if(5)
- H.skin_tone = "african2"
- H.update_body(0)
- else
- H.visible_message("[H] looks a bit dark...", "Your skin suddenly appears darker...")
+ switch(A.stage)
+ if(5)
+ var/static/list/banned_reagents = list(/datum/reagent/colorful_reagent/crayonpowder/invisible, /datum/reagent/colorful_reagent/crayonpowder/white)
+ var/color = pick(subtypesof(/datum/reagent/colorful_reagent/crayonpowder) - banned_reagents)
+ if(M.reagents.total_volume <= (M.reagents.maximum_volume/10)) // no flooding humans with 1000 units of colorful reagent
+ M.reagents.add_reagent(color, 5)
+ else
+ if (prob(50)) // spam
+ M.visible_message("[M] looks rather vibrant...", "The colors, man, the colors...")
diff --git a/code/datums/diseases/advance/symptoms/symptoms.dm b/code/datums/diseases/advance/symptoms/symptoms.dm
index 6783b68bd84..af12960955e 100644
--- a/code/datums/diseases/advance/symptoms/symptoms.dm
+++ b/code/datums/diseases/advance/symptoms/symptoms.dm
@@ -75,7 +75,7 @@
/datum/symptom/proc/generate_threshold_desc()
return
-/datum/symptom/proc/OnAdd(datum/disease/advance/A) //Overload when a symptom needs to be active before processing, like changing biotypes.
+/datum/symptom/proc/OnAdd(datum/disease/advance/A) //Overload when a symptom needs to be active before processing, like changing biotypes.
return
/datum/symptom/proc/OnRemove(datum/disease/advance/A) //But dont forget to remove them too.
diff --git a/code/modules/antagonists/disease/disease_abilities.dm b/code/modules/antagonists/disease/disease_abilities.dm
index 47014b4b010..e521b68aa33 100644
--- a/code/modules/antagonists/disease/disease_abilities.dm
+++ b/code/modules/antagonists/disease/disease_abilities.dm
@@ -27,8 +27,8 @@ new /datum/disease_ability/symptom/medium/nano_boost,
new /datum/disease_ability/symptom/medium/nano_destroy,
new /datum/disease_ability/symptom/medium/viraladaptation,
new /datum/disease_ability/symptom/medium/viralevolution,
-new /datum/disease_ability/symptom/medium/vitiligo,
-new /datum/disease_ability/symptom/medium/revitiligo,
+new /datum/disease_ability/symptom/medium/disfiguration,
+new /datum/disease_ability/symptom/medium/polyvitiligo,
new /datum/disease_ability/symptom/medium/itching,
new /datum/disease_ability/symptom/medium/heal/weight_loss,
new /datum/disease_ability/symptom/medium/heal/sensory_restoration,
@@ -373,11 +373,11 @@ new /datum/disease_ability/symptom/powerful/youth
/datum/disease_ability/symptom/medium/viralevolution
symptoms = list(/datum/symptom/viralevolution)
-/datum/disease_ability/symptom/medium/vitiligo
- symptoms = list(/datum/symptom/vitiligo)
+/datum/disease_ability/symptom/medium/polyvitiligo
+ symptoms = list(/datum/symptom/polyvitiligo)
-/datum/disease_ability/symptom/medium/revitiligo
- symptoms = list(/datum/symptom/revitiligo)
+/datum/disease_ability/symptom/medium/disfiguration
+ symptoms = list(/datum/symptom/disfiguration)
/datum/disease_ability/symptom/medium/itching
symptoms = list(/datum/symptom/itching)
diff --git a/code/modules/reagents/chemistry/reagents/other_reagents.dm b/code/modules/reagents/chemistry/reagents/other_reagents.dm
index 47f2fc1af0d..fa005ba2af3 100644
--- a/code/modules/reagents/chemistry/reagents/other_reagents.dm
+++ b/code/modules/reagents/chemistry/reagents/other_reagents.dm
@@ -1274,9 +1274,6 @@
color = "#FFFFFF" // white
random_color_list = list("#FFFFFF") //doesn't actually change appearance at all
-
-
-
//////////////////////////////////Hydroponics stuff///////////////////////////////
/datum/reagent/plantnutriment
diff --git a/tgstation.dme b/tgstation.dme
index 130a3a0e24b..6c953189ffe 100755
--- a/tgstation.dme
+++ b/tgstation.dme
@@ -448,6 +448,7 @@
#include "code\datums\diseases\advance\symptoms\confusion.dm"
#include "code\datums\diseases\advance\symptoms\cough.dm"
#include "code\datums\diseases\advance\symptoms\deafness.dm"
+#include "code\datums\diseases\advance\symptoms\disfiguration.dm"
#include "code\datums\diseases\advance\symptoms\dizzy.dm"
#include "code\datums\diseases\advance\symptoms\fever.dm"
#include "code\datums\diseases\advance\symptoms\fire.dm"