diff --git a/slave variables documentation - Pregmod.txt b/slave variables documentation - Pregmod.txt
index 07dcf415581dc75e135fd168c38a66b5b661a1e2..6c4f26829a3158087e21dcf7f8e3e5697c3c22f1 100644
--- a/slave variables documentation - Pregmod.txt	
+++ b/slave variables documentation - Pregmod.txt	
@@ -1116,7 +1116,7 @@ accepts string
 
 eyeWear:
 
-Accepts String
+accepts string
 "none"
 "glasses"
 "blurring glasses"
@@ -1124,6 +1124,27 @@ Accepts String
 "blurring contacts"
 "corrective contacts"
 
+hears:
+
+slave hearing
+-2 - deaf
+-1 - hard of hearing
+ 0 - normal
+ 
+earWear:
+
+accepts string
+"none"
+"hearing aids"
+"muffling ear plugs"
+"deafening ear plugs"
+
+earImplant:
+
+is there an inner ear implant device
+0 - no
+1 - yes
+
 origHColor:
 
 slave's original hair color, defaults to their initial hair color.
@@ -3080,7 +3101,7 @@ How to set up your own hero slave.
 
 -The default slave template used:
 
-<<set $activeSlave = {slaveName: "blank", slaveSurname: 0, birthName: "blank", birthSurname: 0, genes: "XX", weekAcquired: 0, origin: 0, career: 0, ID: 0, prestige: 0, pornFame: 0, pornFameSpending: 0, prestigeDesc: 0, recruiter: 0, relation: 0, relationTarget: 0, relationship: 0, relationshipTarget: 0, rivalry: 0, rivalryTarget: 0, subTarget: 0, father: 0, mother: 0, daughters: 0, sisters: 0, canRecruit: 0, choosesOwnAssignment: 0, assignment: "rest", assignmentVisible: 1, sentence: 0, training: 0, toyHole: "all her holes", indenture: -1, indentureRestrictions: 0, birthWeek: random(0,51), actualAge: 18, visualAge: 18, physicalAge: 18, ovaryAge: 18, ageImplant: 0, health: 0, minorInjury: 0, trust: 0, oldTrust: 0, devotion: 0, oldDevotion: 0, weight: 0, muscles: 0, height: 170, heightImplant: 0, nationality: "slave", race: "white", markings: "none", eyes: 1, eyeColor: "brown", origEye: "brown", eyewear: "none", origHColor: "brown", hColor: "brown", pubicHColor: "brown", skin: "light", hLength: 60, hStyle: "short", pubicHStyle: "neat", waist: 0, corsetPiercing: 0, PLimb: 0, amp: 0, heels:0, voice: 2, voiceImplant: 0, accent: 0, shoulders: 0, shouldersImplant: 0, boobs: 0, boobsImplant: 0, boobsImplantType: 0, boobShape: "normal", nipples: "cute",  nipplesPiercing: 0, nipplesAccessory: 0, areolae: 0, areolaePiercing: 0, boobsTat: 0, lactation: 0, lactationAdaptation: 0, milk: 0, cum: 0, hips: 0, hipsImplant: 0, butt: 0, buttImplant: 0, buttImplantType: 0, buttTat: 0, face: 0, faceImplant: 0, faceShape: "normal", lips: 15, lipsImplant: 0, lipsPiercing: 0, lipsTat: 0, teeth: "normal", tonguePiercing: 0, vagina: 0, vaginaLube: 0, vaginaPiercing: 0, vaginaTat: 0, preg: -1, pregSource: 0, pregType: 0, broodmother: 0, broodmotherFetuses: 0, broodmotherOnHold: 0, broodmotherCountDown: 0, labor: 0, births: 0, cSec: 0, bellyAccessory: "none", labia: 0, clit: 0, clitPiercing: 0, clitSetting: "vanilla", foreskin: 0, anus: 0, dick: 0, analArea: 1, dickPiercing: 0, dickTat: 0, prostate: 0, balls: 0, scrotum: 0, ovaries: 0, anusPiercing: 0, anusTat: 0, makeup: 0, nails: 0, brand: 0, brandLocation: 0, earPiercing: 0, nosePiercing: 0, eyebrowPiercing: 0, navelPiercing: 0, shouldersTat: 0, armsTat: 0, legsTat: 0, backTat: 0, stampTat: 0, vaginalSkill: 0, oralSkill: 0, analSkill: 0, whoreSkill: 0, entertainSkill: 0, combatSkill: 0, livingRules: "spare", speechRules: "restrictive", releaseRules: "restrictive", relationshipRules: "restrictive", standardPunishment: "situational", standardReward: "situational", useRulesAssistant: 1, diet: "healthy", dietCum: 0, dietMilk: 0, tired: 0, hormones: 0, drugs: "no drugs", curatives: 0, chem: 0, aphrodisiacs: 0, addict: 0, fuckdoll: 0, choosesOwnClothes: 0, clothes: "no clothing", collar: "none", shoes: "none", vaginalAccessory: "none", dickAccessory: "none", legAccessory: "none", buttplug: "none", buttplugAttachment: "none", intelligence: 0, intelligenceImplant: 0, energy: 50, need: 0, attrXX: 0, attrXY: 0, attrKnown: 0, fetish: "none", fetishStrength: 70, fetishKnown: 0, behavioralFlaw: "none", behavioralQuirk: "none", sexualFlaw: "none", sexualQuirk: "none", oralCount: 0, vaginalCount: 0, analCount: 0, mammaryCount: 0, penetrativeCount: 0, publicCount: 0, pitKills: 0, customTat: "", customLabel: "", customDesc: "", customTitle: "", customTitleLisp: "", rudeTitle: 0, customImage: 0, currentRules: [], bellyTat: 0, induce: 0, mpreg: 0, inflation: 0, inflationType: "none", inflationMethod: 0, milkSource: 0, cumSource: 0, burst: 0, pregKnown: 0, pregWeek: 0, belly: 0, bellyPreg: 0, bellyFluid: 0, bellyImplant: -1, bellySag: 0, bellySagPreg: 0, bellyPain: 0, cervixImplant: 0, birthsTotal: 0, pubertyAgeXX: 13, pubertyAgeXY: 13, scars: 0, breedingMark: 0, underArmHStyle: "waxed", bodySwap: 0, HGExclude: 0, ballType: "human", eggType: "human", reservedChildren: 0, choosesOwnChastity: 0, pregControl: "none", readyLimbs: [], ageAdjust: 0, bald: 0, origBodyOwner: "", death: "", hormoneBalance: 0, onDiet: 0, breastMesh: 0, slavesFathered: 0, PCChildrenFathered: 0, slavesKnockedUp: 0, PCKnockedUp: 0, origSkin: "white", vasectomy: 0, haircuts: 0, newGamePlus: 0, skillHG: 0, skillRC: 0, skillBG: 0, skillMD: 0, skillDJ: 0, skillNU: 0, skillTE: 0, skillAT: 0, skillST: 0, skillMM: 0, skillWA: 0, tankBaby: 0}>>
+<<set $activeSlave = {slaveName: "blank", slaveSurname: 0, birthName: "blank", birthSurname: 0, genes: "XX", weekAcquired: 0, origin: 0, career: 0, ID: 0, prestige: 0, pornFame: 0, pornFameSpending: 0, prestigeDesc: 0, recruiter: 0, relation: 0, relationTarget: 0, relationship: 0, relationshipTarget: 0, rivalry: 0, rivalryTarget: 0, subTarget: 0, father: 0, mother: 0, daughters: 0, sisters: 0, canRecruit: 0, choosesOwnAssignment: 0, assignment: "rest", assignmentVisible: 1, sentence: 0, training: 0, toyHole: "all her holes", indenture: -1, indentureRestrictions: 0, birthWeek: random(0,51), actualAge: 18, visualAge: 18, physicalAge: 18, ovaryAge: 18, ageImplant: 0, health: 0, minorInjury: 0, trust: 0, oldTrust: 0, devotion: 0, oldDevotion: 0, weight: 0, muscles: 0, height: 170, heightImplant: 0, nationality: "slave", race: "white", markings: "none", eyes: 1, eyeColor: "brown", origEye: "brown", eyewear: "none", hears: 0, earwear: "none", earImplant: 0, origHColor: "brown", hColor: "brown", pubicHColor: "brown", skin: "light", hLength: 60, hStyle: "short", pubicHStyle: "neat", waist: 0, corsetPiercing: 0, PLimb: 0, amp: 0, heels:0, voice: 2, voiceImplant: 0, accent: 0, shoulders: 0, shouldersImplant: 0, boobs: 0, boobsImplant: 0, boobsImplantType: 0, boobShape: "normal", nipples: "cute",  nipplesPiercing: 0, nipplesAccessory: 0, areolae: 0, areolaePiercing: 0, boobsTat: 0, lactation: 0, lactationAdaptation: 0, milk: 0, cum: 0, hips: 0, hipsImplant: 0, butt: 0, buttImplant: 0, buttImplantType: 0, buttTat: 0, face: 0, faceImplant: 0, faceShape: "normal", lips: 15, lipsImplant: 0, lipsPiercing: 0, lipsTat: 0, teeth: "normal", tonguePiercing: 0, vagina: 0, vaginaLube: 0, vaginaPiercing: 0, vaginaTat: 0, preg: -1, pregSource: 0, pregType: 0, broodmother: 0, broodmotherFetuses: 0, broodmotherOnHold: 0, broodmotherCountDown: 0, labor: 0, births: 0, cSec: 0, bellyAccessory: "none", labia: 0, clit: 0, clitPiercing: 0, clitSetting: "vanilla", foreskin: 0, anus: 0, dick: 0, analArea: 1, dickPiercing: 0, dickTat: 0, prostate: 0, balls: 0, scrotum: 0, ovaries: 0, anusPiercing: 0, anusTat: 0, makeup: 0, nails: 0, brand: 0, brandLocation: 0, earPiercing: 0, nosePiercing: 0, eyebrowPiercing: 0, navelPiercing: 0, shouldersTat: 0, armsTat: 0, legsTat: 0, backTat: 0, stampTat: 0, vaginalSkill: 0, oralSkill: 0, analSkill: 0, whoreSkill: 0, entertainSkill: 0, combatSkill: 0, livingRules: "spare", speechRules: "restrictive", releaseRules: "restrictive", relationshipRules: "restrictive", standardPunishment: "situational", standardReward: "situational", useRulesAssistant: 1, diet: "healthy", dietCum: 0, dietMilk: 0, tired: 0, hormones: 0, drugs: "no drugs", curatives: 0, chem: 0, aphrodisiacs: 0, addict: 0, fuckdoll: 0, choosesOwnClothes: 0, clothes: "no clothing", collar: "none", shoes: "none", vaginalAccessory: "none", dickAccessory: "none", legAccessory: "none", buttplug: "none", buttplugAttachment: "none", intelligence: 0, intelligenceImplant: 0, energy: 50, need: 0, attrXX: 0, attrXY: 0, attrKnown: 0, fetish: "none", fetishStrength: 70, fetishKnown: 0, behavioralFlaw: "none", behavioralQuirk: "none", sexualFlaw: "none", sexualQuirk: "none", oralCount: 0, vaginalCount: 0, analCount: 0, mammaryCount: 0, penetrativeCount: 0, publicCount: 0, pitKills: 0, customTat: "", customLabel: "", customDesc: "", customTitle: "", customTitleLisp: "", rudeTitle: 0, customImage: 0, currentRules: [], bellyTat: 0, induce: 0, mpreg: 0, inflation: 0, inflationType: "none", inflationMethod: 0, milkSource: 0, cumSource: 0, burst: 0, pregKnown: 0, pregWeek: 0, belly: 0, bellyPreg: 0, bellyFluid: 0, bellyImplant: -1, bellySag: 0, bellySagPreg: 0, bellyPain: 0, cervixImplant: 0, birthsTotal: 0, pubertyAgeXX: 13, pubertyAgeXY: 13, scars: 0, breedingMark: 0, underArmHStyle: "waxed", bodySwap: 0, HGExclude: 0, ballType: "human", eggType: "human", reservedChildren: 0, choosesOwnChastity: 0, pregControl: "none", readyLimbs: [], ageAdjust: 0, bald: 0, origBodyOwner: "", death: "", hormoneBalance: 0, onDiet: 0, breastMesh: 0, slavesFathered: 0, PCChildrenFathered: 0, slavesKnockedUp: 0, PCKnockedUp: 0, origSkin: "white", vasectomy: 0, haircuts: 0, newGamePlus: 0, skillHG: 0, skillRC: 0, skillBG: 0, skillMD: 0, skillDJ: 0, skillNU: 0, skillTE: 0, skillAT: 0, skillST: 0, skillMM: 0, skillWA: 0, tankBaby: 0}>>
 
 Making your slave; add their name to the following, then go down the documentation adding in your changes.
 -each variable must be separated from the last by a comma followed by a space
diff --git a/src/cheats/mod_EditSlaveCheat.tw b/src/cheats/mod_EditSlaveCheat.tw
index 20541a917531f38f1c0aa6084ef07cccc7bd0088..7be911b207fa5f4db5d5cccec174208ad9151e6e 100644
--- a/src/cheats/mod_EditSlaveCheat.tw
+++ b/src/cheats/mod_EditSlaveCheat.tw
@@ -256,6 +256,16 @@ Custom eye color: <<textbox "$activeSlave.eyeColor" $activeSlave.eyeColor>>
 
 <br><br>
 
+''Her hearing is (-1: impaired, 0: normal): $activeSlave.hears''
+<br>Ears: <<textbox "$activeSlave.hears" $activeSlave.hears>>
+<<radiobutton "$activeSlave.hears" 0>> Normal
+<<radiobutton "$activeSlave.hears" -1>> Hard Of Hearing
+<<if $seeExtreme == 1>>
+<<radiobutton "$activeSlave.hears" -2>> Deaf
+<</if>>
+
+<br><br>
+
 ''Change her custom tattoo:'' <<textbox "$activeSlave.customTat" $activeSlave.customTat>>
 <br>
 //For best results, use complete, capitalized and punctuated sentences; for example: 'She has blue stars tattooed along her cheekbones, and a blue arrow down each arm.'//
diff --git a/src/init/storyInit.tw b/src/init/storyInit.tw
index 611f36dddd9bbe4b016b305cae5ca53aeecd26be..74898d421b8b46f75d3a2bb942474befa0cba5f5 100644
--- a/src/init/storyInit.tw
+++ b/src/init/storyInit.tw
@@ -1196,7 +1196,7 @@ DairyRestraintsSetting($dairyRestraintsSetting)
 <<set $weatherToday = $niceWeather.random()>>
 
 <<set $customSlaveOrdered = 0>>
-<<set $customSlave = {age: 19, health: 0, muscles: 0, lips: 15, voice: -1, heightMod: "normal", weight: 0, face: 0, race: "white", skin: "left natural", boobs: 500, butt: 3, sex: 1, virgin: 0, dick: 2, balls: 2, clit: 0, labia: 0, vaginaLube: 1, analVirgin: 0, skills: 15, whoreSkills: 15, combatSkills: 0, intelligence: 0, intelligenceImplant: 1, nationality: "Stateless", amp: 0, eyes: 1}>>
+<<set $customSlave = {age: 19, health: 0, muscles: 0, lips: 15, heightMod: "normal", weight: 0, face: 0, race: "white", skin: "left natural", boobs: 500, butt: 3, sex: 1, virgin: 0, dick: 2, balls: 2, clit: 0, labia: 0, vaginaLube: 1, analVirgin: 0, skills: 15, whoreSkills: 15, combatSkills: 0, intelligence: 0, intelligenceImplant: 1, nationality: "Stateless", amp: 0, eyes: 1, hears: 0}>>
 
 <<set $huskSlaveOrdered = 0>>
 <<set $huskSlave = {age: 18, nationality: "Stateless", race: "white", sex: 1, virgin: 0}>>
diff --git a/src/js/DefaultRules.tw b/src/js/DefaultRules.tw
index f44e8ad9c8ef3c5040bcde961da98ba6e2d941a9..54ce5f1e69660d2b84dbcd7a047173976da0b8f7 100644
--- a/src/js/DefaultRules.tw
+++ b/src/js/DefaultRules.tw
@@ -19,6 +19,7 @@ window.DefaultRules = (function() {
 			ProcessClothing(slave, rule);
 			ProcessCollar(slave, rule);
 			ProcessEyewear(slave, rule);
+			ProcessEarwear(slave, rule);
 			ProcessDildos(slave, rule);
 			ProcessDickAccessories(slave, rule);
 			ProcessAnalAccessories(slave, rule);
@@ -432,6 +433,65 @@ window.DefaultRules = (function() {
 			}
 		}
 	}
+	
+	function ProcessEarwear(slave, rule) {
+		// apply earplugs to slave
+		if ((rule.earwear !== undefined) && (rule.earwear !== "no default setting")) {
+			switch (rule.earwear) {
+				case "correct with hearing aids":
+					if (slave.hears == -1) {
+						if (slave.earwear != "hearing aids") {
+							slave.earwear = "hearing aids";
+							V.cash -= V.modCost;
+							r += `<br>${slave.slaveName} has been given hearing aids.`;
+						}
+					} else {
+						if (slave.earwear != "none") {
+							slave.earwear = "none";
+							r += `<br>${slave.slaveName}'s earwear has been removed.`;
+						}
+					}
+					break;
+
+				case "muffle with ear plugs":
+					if (slave.hears > -1) {
+						if (slave.earwear != "muffling ear plugs") {
+							slave.earwear = "muffling ear plugs";
+							V.cash -= V.modCost;
+							r += `<br>${slave.slaveName} has been given muffling ear plugs.`;
+						}
+					} else {
+						if (slave.earwear != "none") {
+							slave.earwear = "none";
+							r += `<br>${slave.slaveName}'s earwear has been removed.`;
+						}
+					}
+					break;
+
+				case "deafen with ear plugs":
+					if (slave.hears > -2) {
+						if (slave.earwear != "deafening ear plugs") {
+							slave.earwear = "deafening ear plugs";
+							V.cash -= V.modCost;
+							r += `<br>${slave.slaveName} has been given deafening ear plugs.`;
+						}
+					} else {
+						if (slave.earwear != "none") {
+							slave.earwear = "none";
+							r += `<br>${slave.slaveName}'s earwear has been removed.`;
+						}
+					}
+					break;
+
+				default:
+					if (slave.earwear != "none") {
+						slave.earwear = "none";
+						r += `<br>${slave.slaveName}'s earwear has been removed.`;
+					}
+					break;
+			}
+		}
+	}
 
 	function ProcessDildos(slave, rule) {
 		// apply vaginal dildos to slave
diff --git a/src/js/assayJS.tw b/src/js/assayJS.tw
index 3724e4892793b6edec90c72b3435a2f9622e9b29..834e33d36033f37e8b68de1c8ffcf5b581d488ef 100644
--- a/src/js/assayJS.tw
+++ b/src/js/assayJS.tw
@@ -1538,6 +1538,9 @@ window.DegradingName = function DegradingName(slave) {
 		if (slave.eyes === -2) {
 			names.push("Blind", "Eyeless", "Sightless");
 		}
+		if (slave.hears === -2) {
+			names.push("Deaf", "Earless", "Unhearing");
+		}
 		if (slave.boobs >= 2000) {
 			suffixes.push("Boob", "Boobs", "Titty");
 		}
diff --git a/src/js/economyJS.tw b/src/js/economyJS.tw
index 09169b63ce2e1cb42a732913a8ddd74a0631fdf5..62243972e6747801bf59d2887d88930a346793d0 100644
--- a/src/js/economyJS.tw
+++ b/src/js/economyJS.tw
@@ -478,11 +478,18 @@ window.getSlaveCost = function(s) {
 	}
 	if(!canSee(s) && (s.assignment != Job.DAIRY || State.variables.dairyRestraintsSetting < 2) && (s.assignment != Job.ARCADE)) {
 		cost += 50;
-	} else if(s.eyes <= -1 &&	s.eyewear !== 'corrective glasses' && s.eyewear !== 'corrective contacts') {
+	} else if(s.eyes <= -1 && s.eyewear !== 'corrective glasses' && s.eyewear !== 'corrective contacts') {
 		cost += 25;
 	} else if(s.eyewear === 'blurring glasses' || s.eyewear === 'blurring contacts') {
 		cost += 25;
 	}
+	if(!canHear(s) && (s.assignment != Job.DAIRY || State.variables.dairyRestraintsSetting < 2) && (s.assignment != Job.ARCADE)) {
+		cost += 40;
+	} else if(s.hears <= -1 && s.earwear !== 'hearing aids') {
+		cost += 15;
+	} else if(s.earwear === 'muffling ear plugs') {
+		cost += 15;
+	}
 	if((s.assignment !== Job.DAIRY || State.variables.dairyRestraintsSetting < 2) && (s.assignment !== Job.ARCADE)) {
 		if(s.amp !== 0) {
 			if(s.amp === 1) {
diff --git a/src/js/rulesAssistantOptions.tw b/src/js/rulesAssistantOptions.tw
index f23c50dabf5e827dabb1aea4d563a00a2487f9d2..6bdaadb1880c517ba235c052e22f72b706815198 100644
--- a/src/js/rulesAssistantOptions.tw
+++ b/src/js/rulesAssistantOptions.tw
@@ -976,6 +976,7 @@ window.rulesAssistantOptions = (function() {
 			super("Cosmetic Settings", true);
 			this.appendChild(new EyewearList());
 			this.appendChild(new LensesList());
+			this.appendChild(new EarwearList());
 			this.appendChild(new MakeupList());
 			this.appendChild(new NailsList());
 			this.appendChild(new HairLengthList());
@@ -2047,6 +2048,19 @@ window.rulesAssistantOptions = (function() {
 			super(items);
 		}
 	}
+	
+	class EarwearList extends List {
+		constructor() {
+			const pairs = [
+				["correct with hearing aids"],
+				["muffle with ear plugs"],
+				["deafen with ear plugs"]
+			];
+			super("Earwear", pairs);
+			this.setValue(current_rule.set.earwear);
+			this.onchange = (value) => current_rule.set.earwear = value;
+		}
+	}
 
 	class MakeupList extends List {
 		constructor() {
diff --git a/src/js/slaveGenerationJS.tw b/src/js/slaveGenerationJS.tw
index db33dd23bb198974241b8e56efb1e15b65498856..5f58b70250c18ae11810fb596b5bbf6172c8b8ed 100644
--- a/src/js/slaveGenerationJS.tw
+++ b/src/js/slaveGenerationJS.tw
@@ -192,19 +192,19 @@ window.nationalityToAccent = function nationalityToAccent(slave) {
 			slave.accent = (V.language === "English") ? jsEither([0, 1, 1, 1, 2]) : naturalAccent;
 			break;
 		case "Beninese":
-			slave.accent = (V.language === "French") ? 1 : naturalAccent;
+			slave.accent = (V.language === "French") ? jsEither([0, 1, 1, 1, 2]) : naturalAccent;
 			break;
 		case "Bermudian":
-			slave.accent = (V.language === "English") ? 1 : naturalAccent;
+			slave.accent = (V.language === "English") ? jsEither([0, 1, 1, 1, 2]) : naturalAccent;
 			break;
 		case "Bhutanese":
 			slave.accent = (V.language === "Dzongkha") ? jsEither([0, 0, 0, 1]) : naturalAccent;
 			break;
 		case "Bissau-Guinean":
-			slave.accent = (V.language === "Portuguese") ? 1 : naturalAccent;
+			slave.accent = (V.language === "Portuguese") ? jsEither([0, 1, 1, 1, 2]) : naturalAccent;
 			break;
 		case "Bolivian":
-			slave.accent = (V.language === "Spanish") ? 1 : naturalAccent;
+			slave.accent = (V.language === "Spanish") ? jsEither([0, 1, 1, 1, 2]) : naturalAccent;
 			break;
 		case "Bosnian":
 			slave.accent = naturalAccent;
diff --git a/src/js/slaveSummaryWidgets.tw b/src/js/slaveSummaryWidgets.tw
index 3607d45746eb9b9e675c7893f5a95ba920abb7fe..7d256d9a4cf9230e1e3fbdbef35109854d7f7475 100644
--- a/src/js/slaveSummaryWidgets.tw
+++ b/src/js/slaveSummaryWidgets.tw
@@ -87,6 +87,7 @@ window.SlaveSummaryUncached = (function(){
 			short_age(slave);
 			short_face(slave);
 			short_eyes(slave);
+			short_ears(slave);
 			if (slave.markings !== "none")
 				r += `Markings`;
 			short_lips(slave);
@@ -105,6 +106,7 @@ window.SlaveSummaryUncached = (function(){
 			long_age(slave);
 			long_face(slave);
 			long_eyes(slave);
+			long_ears(slave);
 			long_lips(slave);
 			long_teeth(slave);
 			long_muscles(slave);
@@ -1952,12 +1954,21 @@ window.SlaveSummaryUncached = (function(){
 	function short_eyes(slave) {
 		if (slave.eyes === -2) {
 			r += `<span class="red">Blind</span>`;
-		} else if (((slave.eyes === -1) && (slave.eyewear !== "corrective glasses") && (slave.eyewear !== "corrective contacts"))) {
+		} else if (((slave.eyes === -1) && (slave.eyewear !== "corrective glasses") && (slave.eyewear !== "corrective contacts")) || (slave.eyewear === "blurring glasses") || (slave.eyewear === "blurring contacts")) {
 			r += `<span class="yellow">Sight-</span>`;
 		}
 		r += " ";
 	}
 	
+	function short_ears(slave) {
+		if (slave.hears === -2) {
+			r += `<span class="red">Deaf</span>`;
+		} else if ((slave.hears === -1) && (slave.earwear !== "hearing aids")) {
+			r += `<span class="yellow">Hearing-</span>`;
+		}
+		r += " ";
+	}
+	
 	function short_lips(slave) {
 		if (slave.lips > 95) {
 			r += `Facepussy`;
@@ -2257,12 +2268,21 @@ window.SlaveSummaryUncached = (function(){
 	function long_eyes(slave) {
 		if (slave.eyes <= -2) {
 			r += `<span class="red">Blind.</span>`;
-		} else if (((slave.eyes <= -1) && (slave.eyewear !== "corrective glasses") && (slave.eyewear !== "corrective contacts"))) {
+		} else if (((slave.eyes === -1) && (slave.eyewear !== "corrective glasses") && (slave.eyewear !== "corrective contacts")) || (slave.eyewear === "blurring glasses") || (slave.eyewear === "blurring contacts")) {
 			r += `<span class="yellow">Nearsighted.</span>`;
 		}
 		r += " ";
 	}
 	
+	function long_ears(slave) {
+		if (slave.hears <= -2) {
+			r += `<span class="red">Deaf.</span>`;
+		} else if ((slave.hears === -1) && (slave.earwear !== "hearing aids")) {
+			r += `<span class="yellow">Hard of hearing.</span>`;
+		}
+		r += " ";
+	}
+	
 	function long_lips(slave) {
 		if (slave.lips > 95) {
 			r += `Facepussy${V.summaryStats? `[${slave.lips}]`: ''}.`;
diff --git a/src/js/storyJS.tw b/src/js/storyJS.tw
index db35a0008ef8472666efe5226c8582448ec858f5..f72b2f171a145c9779d9c2817c01fa4afa503fcb 100644
--- a/src/js/storyJS.tw
+++ b/src/js/storyJS.tw
@@ -370,7 +370,7 @@ window.canSee = function(slave) {
 window.canHear = function(slave) {
 	if (!slave) {
 		return null;
-	} else if (slave.hears > -2) {
+	} else if ((slave.hears > -2) || (slave.earwear !== "deafening ear plugs") {
 		return true;
 	} else {
 		return false;
diff --git a/src/npc/uploadSlave.tw b/src/npc/uploadSlave.tw
index f8f4d2ae3d80708f425c06676f56e9803d194146..e754213ea14e98ae0e5464d5988f9f197a97cca2 100644
--- a/src/npc/uploadSlave.tw
+++ b/src/npc/uploadSlave.tw
@@ -55,6 +55,9 @@ markings: "none",
 eyes: "$activeSlave.eyes",
 eyeColor: "$activeSlave.eyeColor",
 eyewear: "none",
+ears: "$activeSlave.hears",
+earwear: "none",
+earImplant: 0,
 hColor: "$activeSlave.hColor",
 pubicHColor: "$activeSlave.pubicHColor",
 skin: "$activeSlave.skin",
diff --git a/src/pregmod/widgets/bodySwapReaction.tw b/src/pregmod/widgets/bodySwapReaction.tw
index c1226937c580542f598e5a2ec661d678bf4c6810..9f105a7a8fe56eb2e775d115bacf413680de7eaa 100644
--- a/src/pregmod/widgets/bodySwapReaction.tw
+++ b/src/pregmod/widgets/bodySwapReaction.tw
@@ -13,6 +13,17 @@
 <<else>>
 	<<set _sight = 0>> /* no change */
 <</if>>
+<<if $args[0].hears <= -2 && $args[1].hears > -2>>
+	<<set _hearing = -2>> /* now deaf */
+<<elseif $args[0].hears == -1 && $args[1].hears > -1>>
+	<<set _hearing = -1>> /* now hard of hearing */
+<<elseif $args[0].hears > -2 && $args[1].hears <= -2>>
+	<<set _hearing = 2>>	/* now not deaf */
+<<elseif $args[0].hears > -1 && $args[1].hears == -1>>
+	<<set _hearing = 1>> /* now not hard of hearing */
+<<else>>
+	<<set _hearing = 0>> /* no change */
+<</if>>
 <<set _end = 0>>
 
 <<if $args[0].health >= $args[1].health+10>>
diff --git a/src/pregmod/widgets/bodyswapWidgets.tw b/src/pregmod/widgets/bodyswapWidgets.tw
index 8ce195237b2539a5496f4ddeef7720ecb0d222de..b5bc4a328ddf88635a2c1f6cbe68e36c722d78c4 100644
--- a/src/pregmod/widgets/bodyswapWidgets.tw
+++ b/src/pregmod/widgets/bodyswapWidgets.tw
@@ -67,6 +67,9 @@
 <<set $args[0].origEye = $args[1].origEye>>
 <<set $args[0].eyeColor = $args[1].eyeColor>>
 <<set $args[0].eyeWear = $args[1].eyeWear>>
+<<set $args[0].hears = $args[1].hears>>
+<<set $args[0].earwear = $args[1].earwear>>
+<<set $args[0].earImplant = $args[1].earImplant>>
 <<set $args[0].origHColor = $args[1].origHColor>>
 <<set $args[0].hColor = $args[1].hColor>>
 <<set $args[0].hLength = $args[1].hLength>>
diff --git a/src/uncategorized/clubReport.tw b/src/uncategorized/clubReport.tw
index 9b53b34a4abfadb3ae3464d88fd615eef13086a0..075729ed090a6cf4fd2c1154c48755ae4441e678 100644
--- a/src/uncategorized/clubReport.tw
+++ b/src/uncategorized/clubReport.tw
@@ -56,10 +56,19 @@
 	<<elseif (_FLsFetish == 2)>>
 		Every day she gets to enjoy hundreds of stares on her skin, and @@.lightsalmon;becomes more of an exhibitionist.@@
 	<</if>>
-	<<if ($DJ.eyes == -2)>>
+	<<if ($DJ.eyes == -2) && ($DJ.hears >= -2)>>
 		Her lack of eyesight doesn't slow her down; rather, it strengthens her other senses. Her tracks have a distinct sound, since she experiences noise as her sight.
 		<<set $DJRepBonus += 0.15>>
 	<</if>>
+	<<if ($DJ.hears <= 0)>>
+		<<if ($DJ.hears == -2)>>
+			Her lack of hearing makes her a laughably poor choice for DJ.
+			<<set $DJRepBonus -= 0.20>>
+		<<elseif ($DJ.hears == -1)>>
+			Her poor sense of hearing makes her a poor choice for DJ.
+			<<set $DJRepBonus -= 0.10>>
+		<</if>>
+	<</if>>
 	<<if ($DJ.entertainSkill <= 10)>>
 		Though $DJ.slaveName does her best to lead on the club, with her lack of skill she can do little.
 	<<elseif ($DJ.entertainSkill <= 30)>>
diff --git a/src/uncategorized/costsReport.tw b/src/uncategorized/costsReport.tw
index 4e6e817f293f6536d9468271b701996fb66b6154..a2ea4792cbcf815f3a9678efcd3f144a36943397 100644
--- a/src/uncategorized/costsReport.tw
+++ b/src/uncategorized/costsReport.tw
@@ -372,44 +372,44 @@ your __personal living expenses__ are <<print cashFormat(($girls*(250+($economy*
 		<<set $individualCosts += 50>>
 	<</switch>>
 	<<if $boobAccessibility != 1>>
-	<<if ($slaves[$i].boobs > 20000)>>
-	<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to inconveniently huge boobs: <<print cashFormat(50)>>
-		<<set $individualCosts += 50>>
-	<</if>>
-	<</if>>
+		<<if ($slaves[$i].boobs > 20000)>>
+			<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to inconveniently huge boobs: <<print cashFormat(50)>>
+				<<set $individualCosts += 50>>
+			<</if>>
+		<</if>>
 	<</if>>
 	<<if $pregAccessibility != 1>>
-	<<if ($slaves[$i].belly >= 60000)>>
-	<<if ($slaves[$i].assignment != "labor in the production line") && ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
-	  <br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to an inconveniently huge belly: <<print cashFormat(100)>>
-	  <<set $individualCosts += 100>>
-	<</if>>
-	<</if>>
+		<<if ($slaves[$i].belly >= 60000)>>
+			<<if ($slaves[$i].assignment != "labor in the production line") && ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to an inconveniently huge belly: <<print cashFormat(100)>>
+				<<set $individualCosts += 100>>
+			<</if>>
+		<</if>>
 	<</if>>
 	<<if $dickAccessibility != 1>>
-	<<if ($slaves[$i].dick > 45)>>
-	<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to an inconveniently huge penis: <<print cashFormat(50)>>
-		<<set $individualCosts += 50>>
-	<</if>>
-	<</if>>
+		<<if ($slaves[$i].dick > 45)>>
+			<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to an inconveniently huge penis: <<print cashFormat(50)>>
+				<<set $individualCosts += 50>>
+			<</if>>
+		<</if>>
 	<</if>>
 	<<if $ballsAccessibility != 1>>
-	<<if ($slaves[$i].balls > 90)>>
-	<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to inconveniently huge balls: <<print cashFormat(50)>>
-		<<set $individualCosts += 50>>
-	<</if>>
-	<</if>>
+		<<if ($slaves[$i].balls > 90)>>
+			<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to inconveniently huge balls: <<print cashFormat(50)>>
+				<<set $individualCosts += 50>>
+			<</if>>
+		<</if>>
 	<</if>>
 	<<if $buttAccessibility != 1>>
-	<<if ($slaves[$i].butt > 15)>>
-	<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to an inconveniently huge butt: <<print cashFormat(50)>>
-		<<set $individualCosts += 50>>
-	<</if>>
-	<</if>>
+		<<if ($slaves[$i].butt > 15)>>
+			<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to an inconveniently huge butt: <<print cashFormat(50)>>
+				<<set $individualCosts += 50>>
+			<</if>>
+		<</if>>
 	<</if>>
 	<<if !canSee($slaves[$i]) && ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
 		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to lack of sight: <<print cashFormat(50)>>
@@ -421,43 +421,53 @@ your __personal living expenses__ are <<print cashFormat(($girls*(250+($economy*
 		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to blurred vision: <<print cashFormat(25)>>
 		<<set $individualCosts += 25>>
 	<</if>>
-	<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
-	<<if ($slaves[$i].amp != 0)>>
-	  <<if ($slaves[$i].amp == 1)>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to limblessness: <<print cashFormat($rulesCost)>>
-		<<set $individualCosts += $rulesCost>>
-	  <<else>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to prosthetics: <<print cashFormat($rulesCost/2)>>
-		<<set $individualCosts += $rulesCost/2>>
-	  <</if>>
-	<<elseif !canWalk($slaves[$i])>>
-	  <br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to immobility: <<print cashFormat($rulesCost)>>
-	  <<set $individualCosts += $rulesCost>>
+	<<if !canHear($slaves[$i]) && ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
+		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to lack of hearing: <<print cashFormat(40)>>
+		<<set $individualCosts += 40>>
+	<<elseif $slaves[$i].hears <= -1 && $slaves[$i].earwear != "hearing aids">>
+		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to poor hearing: <<print cashFormat(15)>>
+		<<set $individualCosts += 15>>
+	<<elseif ($slaves[$i].earwear == "muffling ear plugs")>>
+		<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to muffled hearing: <<print cashFormat(15)>>
+		<<set $individualCosts += 15>>
 	<</if>>
+	<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2) && ($slaves[$i].assignment != "be confined in the arcade")>>
+		<<if ($slaves[$i].amp != 0)>>
+			<<if ($slaves[$i].amp == 1)>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to limblessness: <<print cashFormat($rulesCost)>>
+				<<set $individualCosts += $rulesCost>>
+			<<else>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to prosthetics: <<print cashFormat($rulesCost/2)>>
+				<<set $individualCosts += $rulesCost/2>>
+			<</if>>
+		<<elseif !canWalk($slaves[$i])>>
+			<br>&nbsp;&nbsp;&nbsp;&nbsp;Increased living expenses due to immobility: <<print cashFormat($rulesCost)>>
+			<<set $individualCosts += $rulesCost>>
+		<</if>>
 	<</if>>
 	<<if $slaves[$i].boobs > 10000>>
-	<<if $slaves[$i].boobsImplantType == 1>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Maintenance cost for oversized string implants: <<print cashFormat(50)>>
-		<<set $individualCosts += 50>>
-	<</if>>
+		<<if $slaves[$i].boobsImplantType == 1>>
+			<br>&nbsp;&nbsp;&nbsp;&nbsp;Maintenance cost for oversized string implants: <<print cashFormat(50)>>
+			<<set $individualCosts += 50>>
+		<</if>>
 	<</if>>
 	<<if $slaves[$i].butt > 10>>
-	<<if $slaves[$i].buttImplantType == 1>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Maintenance cost for oversized string implants: <<print cashFormat(50)>>
-		<<set $individualCosts += 50>>
-	<</if>>
+		<<if $slaves[$i].buttImplantType == 1>>
+			<br>&nbsp;&nbsp;&nbsp;&nbsp;Maintenance cost for oversized string implants: <<print cashFormat(50)>>
+			<<set $individualCosts += 50>>
+		<</if>>
 	<</if>>
 	<<if $slaves[$i].preg > 35>>
-	<<if $universalRulesBirthing == 1>>
-	<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2)>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Coverage cost for daily pregnancy scanning: <<print cashFormat(50)>>
-		<<set $individualCosts += 50>>
-	<</if>>
-	<</if>>
+		<<if $universalRulesBirthing == 1>>
+			<<if ($slaves[$i].assignment != "work in the dairy" || $dairyRestraintsSetting < 2)>>
+				<br>&nbsp;&nbsp;&nbsp;&nbsp;Coverage cost for daily pregnancy scanning: <<print cashFormat(50)>>
+				<<set $individualCosts += 50>>
+			<</if>>
+		<</if>>
 	<</if>>
 	<<if $CitizenRetirement == 1>>
-	<br>&nbsp;&nbsp;&nbsp;&nbsp;Retirement account payments: <<print cashFormat(250)>>
-	<<set $individualCosts += 250>>
+		<br>&nbsp;&nbsp;&nbsp;&nbsp;Retirement account payments: <<print cashFormat(250)>>
+		<<set $individualCosts += 250>>
 	<</if>>
 	<<if ($slaves[$i].inflation == 3)>>
 		<<switch $slaves[$i].inflationType>>
@@ -539,10 +549,10 @@ your __personal living expenses__ are <<print cashFormat(($girls*(250+($economy*
 		<<set $individualCosts += Math.trunc($drugsCost*0.5)>>
 	<</if>>
 	<<if ($studio == 1)>>
-	<<if ($slaves[$i].pornFameSpending > 0)>>
-		<br>&nbsp;&nbsp;&nbsp;&nbsp;Publicity: <<print cashFormat($slaves[$i].pornFameSpending/$PCSlutContacts)>>
-		<<set $individualCosts += ($slaves[$i].pornFameSpending/$PCSlutContacts)>>
-	<</if>>
+		<<if ($slaves[$i].pornFameSpending > 0)>>
+			<br>&nbsp;&nbsp;&nbsp;&nbsp;Publicity: <<print cashFormat($slaves[$i].pornFameSpending/$PCSlutContacts)>>
+			<<set $individualCosts += ($slaves[$i].pornFameSpending/$PCSlutContacts)>>
+		<</if>>
 	<</if>>
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;__Total__: <<print cashFormat(Math.trunc($individualCosts))>>
 	<br>
diff --git a/src/uncategorized/longSlaveDescription.tw b/src/uncategorized/longSlaveDescription.tw
index 5a633901f3b84f4592c00759802cf08c8ff6df01..a867ce2886d8f05ce413c0d195112531cd6ea7f9 100644
--- a/src/uncategorized/longSlaveDescription.tw
+++ b/src/uncategorized/longSlaveDescription.tw
@@ -15,10 +15,8 @@
 <</if>>
 /* 000-250-006 */
 
-
 &nbsp;&nbsp;&nbsp;&nbsp;
 
-
 ''@@.pink;<<= SlaveFullName($activeSlave)>>@@''
 
 <<if $activeSlave.customLabel>> (@@.yellow;''<<print $activeSlave.customLabel>>''@@)<</if>>
@@ -1994,6 +1992,8 @@ $He is
 
 <<if ($showClothing == 1) && ($saleDescription == 0)>>
 
+	<<earDescription>>
+
 	<<upperFaceDescription>>
 
 	<<HairDescription>>
diff --git a/src/uncategorized/saLongTermEffects.tw b/src/uncategorized/saLongTermEffects.tw
index ca4bc45c4ca4f7a4a679e09d4d8e42871fb02263..73e50ae7ca436bed790974a1ffc541cbc90f0e00 100644
--- a/src/uncategorized/saLongTermEffects.tw
+++ b/src/uncategorized/saLongTermEffects.tw
@@ -2433,7 +2433,7 @@
 				$His life used to revolve around being pregnant all the time and nothing has changed. However, being surrounded with happy, heavily pregnant women leaves $him @@.hotpink;slightly more accepting@@ of $his fate and @@.mediumaquamarine;hopeful@@ that $his trained body will be useful to you.
 				<<set $slaves[$i].trust += 1, $slaves[$i].devotion += 1>>
 			<<elseif $slaves[$i].pregControl == "speed up">>
-				$His life used to revolve around being pregnant all the time and nothing has changed. $He @@.gold;watches in horror@@ as $his middle visibly swells before $his eyes. $He @@.hotpink;slips more into submission@@ as the pressure in $his womb increases.
+				$His life used to revolve around being pregnant all the time and nothing has changed. <<if !canSee($slaves[$i])>>$He can feel $his middle swell at a rate $he considers unnatural, which @@.gold;frightens $him.@@<<else>>$He @@.gold;watches in horror@@ as $his middle visibly swells before $his eyes.<</if>> $He @@.hotpink;slips more into submission@@ as the pressure in $his womb increases.
 				<<set $slaves[$i].trust -= 10, $slaves[$i].devotion += 5>>
 			<<elseif $slaves[$i].pregKnown == 1 || $slaves[$i].pregWeek < 0>>
 				$His life used to revolve around being pregnant all the time and nothing has changed. $He @@.gold;fears@@ that $his entire life will revolve around pregnancy and @@.hotpink;slips more into submission@@ of $his fate.
@@ -5823,6 +5823,53 @@
 					<</if>>
 				<</if>>
 			<</if>>
+			<<if $slaves[$i].hears == -2>>
+				<<if $slaves[$i].devotion > 50>>
+					Even though $he is deaf, $he is devoted enough to you to allow $himself to lower $his guard. $He becomes @@.mediumaquamarine;trusting@@ of your ability to keep $him safe.
+					<<set $slaves[$i].trust += 3>>
+				<<elseif $slaves[$i].devotion > 20>>
+					Since $he's deaf and on the cusp of devotion, $he becomes slightly @@.hotpink;more reliant@@, but also begins to be @@.mediumaquamarine;less fearful@@ of what $he can't hear.
+					<<set $slaves[$i].devotion += 3, $slaves[$i].trust += 1>>
+				<<elseif ["please you", "be your Concubine", "serve in the master suite"].includes($slaves[$i].assignment)>>
+					$He may be deaf, but $he knows nobody would dare harm $him under your watch, @@.mediumaquamarine;building $his trust@@ in you.
+					<<set $slaves[$i].trust += 2>>
+				<<elseif $slaves[$i].devotion > -20>>
+					$His deafness forces $him to @@.hotpink;rely@@ on your mercy. However, it only @@.gold;amplifies $his fear@@ as $he has severely limited capabilities to defend $himself.
+					<<set $slaves[$i].devotion += 5, $slaves[$i].trust -= 10>>
+				<<else>>
+					Being deaf forces $him to @@.hotpink;completely rely@@ on your mercy. It does nothing to stem @@.gold;the terror@@ $he faces constantly being unable to tell what will happen to $him.
+					<<set $slaves[$i].devotion += 10, $slaves[$i].trust -= 25>>
+				<</if>>
+			<<elseif $slaves[$i].hears == -1>>
+				<<if ($slaves[$i].earwear != "hearing aids")>>
+					<<if $slaves[$i].devotion > 50>>
+					<<elseif $slaves[$i].devotion > 20>>
+						Since $he's on the cusp of devotion, $his muffled hearing makes $him @@.hotpink;slightly more submissive,@@ since $he can't always hear what's happening to $him.
+						<<set $slaves[$i].devotion += 1>>
+					<<elseif ($slaves[$i].assignment == "serve the public") || ($slaves[$i].assignment == "serve in the club") || ($slaves[$i].assignment == "whore") || ($slaves[$i].assignment == "work in the brothel")>>
+						$His muffled hearing @@.hotpink;reduces $his distaste for $his life slightly,@@ since $his impaired hearing allows $him to ignore the details of everyone $he's expected to fuck.
+						<<set $slaves[$i].devotion += 1>>
+					<<else>>
+						$His muffled hearing tends to make $him @@.mediumorchid;a little more fearful,@@ since $he can never tell what's about to happen to $him.
+						<<set $slaves[$i].trust -= 1>>
+					<</if>>
+				<</if>>
+			<<elseif $slaves[$i].hears == 0>>
+				<<if ($slaves[$i].earwear == "muffling ear plugs")>>
+					<<if $slaves[$i].devotion > 50>>
+						$He tolerates the annoyance of muffled hearing induced by $his earwear.
+					<<elseif $slaves[$i].devotion > 20>>
+						Since $he's on the cusp of devotion, the muffled hearing induced by $his earwear actually makes $him @@.hotpink;slightly more submissive.@@
+						<<set $slaves[$i].devotion += 1>>
+					<<elseif ($slaves[$i].assignment == "serve the public") || ($slaves[$i].assignment == "serve in the club") || ($slaves[$i].assignment == "whore") || ($slaves[$i].assignment == "work in the brothel")>>
+						The muffled hearing induced by $his earwear actually @@.hotpink;reduces $his distaste for $his life slightly,@@ since $his impaired hearing allows $him to ignore the details of everyone $he's expected to fuck.
+						<<set $slaves[$i].devotion += 1>>
+					<<else>>
+						The muffled hearing induced by $his earwear actually @@.mediumorchid;infuriates $him.@@
+						<<set $slaves[$i].devotion -= 1>>
+					<</if>>
+				<</if>>
+			<</if>>
 		<</if>>
 	<</if>>
 <</if>>
@@ -7012,6 +7059,12 @@
 			<<set $slaves[$i].eyes = -1>>
 		<</if>>
 	<</if>>
+	<<if $slaves[$i].hears >= 0>>
+		<<if $slaves[$i].fuckdoll > random(20,100)>>
+			$His suit deafens $him, and $his @@.mediumorchid;hearing worsens@@ from long disuse.
+			<<set $slaves[$i].hears = -1>>
+		<</if>>
+	<</if>>
 	<<if $slaves[$i].curatives == 0 && $slaves[$i].inflationType != "curative">>
 		The extreme physical stress of living in the suit @@.red;damages $his health.@@
 		<<set $slaves[$i].health = -10>>
diff --git a/src/uncategorized/salon.tw b/src/uncategorized/salon.tw
index 63522b63afc5117c4a0c7d0752ac00e5ff91e2a2..ac86878b4435f7cd88367b61214bf953e419c6ee 100644
--- a/src/uncategorized/salon.tw
+++ b/src/uncategorized/salon.tw
@@ -6,8 +6,17 @@
 
 <h1>The Auto Salon</h1>
 
-//$activeSlave.slaveName is seated in the auto salon. $pronounCap is awaiting your artistic pleasure.//
+//$activeSlave.slaveName is seated in the auto salon. $He is awaiting your artistic pleasure.//
 
+/* 000-250-006 */
+<<if $seeImages == 1>>
+	<<if $imageChoice == 1>>
+		<div class="imageRef lrgVector"><div class="mask">&nbsp;</div><<SlaveArt $activeSlave 3 0>></div>
+	<<else>>
+		<div class="imageRef lrgRender"><div class="mask">&nbsp;</div><<SlaveArt $activeSlave 3 0>></div>
+	<</if>>
+<</if>>
+/* 000-250-006 */
 
 /* EYES */
 
@@ -15,18 +24,8 @@
 
 <br><br>
 
-/* 000-250-006 */
-<<if $seeImages == 1>>
-<<if $imageChoice == 1>>
-    <div class="imageRef lrgVector"><div class="mask">&nbsp;</div><<SlaveArt $activeSlave 3 0>></div>
-<<else>>
-    <div class="imageRef lrgRender"><div class="mask">&nbsp;</div><<SlaveArt $activeSlave 3 0>></div>
-<</if>>
-<</if>>
-/* 000-250-006 */
-
 <<if $activeSlave.origEye == "implant">>
-	$pronounCap has artificial eyes, and $pronoun
+	$He has artificial eyes, and $he
 	<<if $activeSlave.eyewear == "none">>
 		has no eyewear.  
 	<<else>>
@@ -37,7 +36,7 @@
 	Give her: [[Cosmetic glasses|Salon][$activeSlave.eyewear = "glasses",$cash -= $modCost]]
 	<br>
 <<elseif $activeSlave.eyes < -1>>
-	$pronounCap is blind, and 
+	$He is blind, and 
 	<<if $activeSlave.eyewear == "none">>
 		has no eyewear.  
 	<<else>>
@@ -47,7 +46,7 @@
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
 	Give her: [[Cosmetic glasses|Salon][$activeSlave.eyewear = "glasses",$cash -= $modCost]]
 <<elseif $activeSlave.eyes > -1>>
-	$possessiveCap vision is normal, and $pronoun
+	$His vision is normal, and $he
 	<<if $activeSlave.eyewear == "none">>
 		has no eyewear.  
 	<<else>>
@@ -59,7 +58,7 @@
 	| [[Blurring glasses|Salon][$activeSlave.eyewear = "blurring glasses",$cash -= $modCost]]
 	| [[Blurring contacts|Salon][$activeSlave.eyewear = "blurring contacts",$cash -= $modCost]]
 <<else>>
-	$pronounCap is nearsighted, and $pronoun
+	$He is nearsighted, and $he
 	<<if $activeSlave.eyewear == "none">>
 		has no eyewear.  
 	<<else>>
@@ -77,17 +76,17 @@
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
 	Custom cosmetic lenses:
 	<<if $activeSlave.origEye != "none">>
-		$possessiveCap eyes are $activeSlave.eyeColor.  
+		$His eyes are $activeSlave.eyeColor.  
 		<<if $activeSlave.origEye != $activeSlave.eyeColor>>
 			[[Remove lenses|Salon][$activeSlave.eyeColor = $activeSlave.origEye]] or //choose new ones://
 		<<else>>
-			//Choose $possessive cosmetic lenses:
+			//Choose $his cosmetic lenses:
 		<</if>>
 	<<else>>
 		<<if $activeSlave.eyeColor == "empty">>
-			$possessiveCap has no eyes.  //Choose what kind of eyes you want $possessive to have://
+			$He has no eyes.  //Choose what kind of eyes you want $his to have://
 		<<else>>
-			$possessiveCap glass eyes are $activeSlave.eyeColor.  [[Remove eyes|Salon][$activeSlave.eyeColor = "empty"]] or //choose new ones://
+			$His glass eyes are $activeSlave.eyeColor.  [[Remove eyes|Salon][$activeSlave.eyeColor = "empty"]] or //choose new ones://
 		<</if>>
 	<</if>>	
 	
@@ -128,17 +127,72 @@
 		[[Give|Salon][$activeSlave.eyeColor = ($artificialEyeShape + " " + $artificialEyeColor),$cash -= $modCost, $artificialEyeColor = "", $artificialEyeShape = ""]] her $artificialEyeShape $artificialEyeColor <<if $activeSlave.origEye == "none">> glass eyes<<else>>lenses<</if>>? //This will be applied in addition to eyewear choices.//
 	<</if>>
 <<else>>
-	$possessiveCap eyes are artificial and can't be set here.
+	$His eyes are artificial and can't be set here.
 <</if>>
 <</if>> /*End eye check */
 
+/* EARS */
+
+<<if $activeSlave.earImplant == 1>>
+	$He has artificial inner ear implants,
+	<<if $activeSlave.earwear == "none">>
+		which are unobstructed.  
+	<<else>>
+		and is wearing $activeSlave.earwear.  [[Remove|Salon][$activeSlave.earwear = "none"]]  
+	<</if>>
+	//Blurring options are annoying and impede performance on some assignments.//
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;
+	Give $him: [[Hearing aids|Salon][$activeSlave.earwear = "hearing aids",$cash -= $modCost]]
+	| [[Muffling ear plugs|Salon][$activeSlave.earwear = "muffling ear plugs",$cash -= $modCost]]
+	| [[Deafening ear plugs|Salon][$activeSlave.earwear = "deafening ear plugs",$cash -= $modCost]]
+	<br>
+<<elseif $activeSlave.hears < -1>>
+	$He is deaf, and 
+	<<if $activeSlave.earwear == "none">>
+		is wearing nothing on $his ears.  
+	<<else>>
+		is wearing $activeSlave.earwear.  [[Remove|Salon][$activeSlave.earwear = "none"]]  
+	<</if>>
+	//Blurring options are annoying and impede performance on some assignments.//
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;
+	Give $him: [[Hearing aids|Salon][$activeSlave.earwear = "hearing aids",$cash -= $modCost]]
+	| [[Muffling ear plugs|Salon][$activeSlave.earwear = "muffling ear plugs",$cash -= $modCost]]
+	| [[Deafening ear plugs|Salon][$activeSlave.earwear = "deafening ear plugs",$cash -= $modCost]]
+<<elseif $activeSlave.hears > -1>>
+	$His hearing is normal, and $he
+	<<if $activeSlave.earwear == "none">>
+		has nothing in $his ears.  
+	<<else>>
+		is wearing $activeSlave.earwear.  [[Remove|Salon][$activeSlave.eyewear = "none"]]  
+	<</if>>
+	//Blurring options are annoying and impede performance on some assignments.//
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;
+	Give $him: [[Hearing aids|Salon][$activeSlave.earwear = "hearing aids",$cash -= $modCost]]
+	| [[Muffling ear plugs|Salon][$activeSlave.earwear = "muffling ear plugs",$cash -= $modCost]]
+	| [[Deafening ear plugs|Salon][$activeSlave.earwear = "deafening ear plugs",$cash -= $modCost]]
+<<else>>
+	$He is hearing impaired, and
+	<<if $activeSlave.earwear == "none">>
+		wears nothing to correct or worsen this.  
+	<<else>>
+		is wearing $activeSlave.earwear.  [[Remove|Salon][$activeSlave.earwear = "none"]]  
+	<</if>>
+	//Hearing impairment will impede performance on some assignments.//
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;
+	Give $him: [[Hearing aids|Salon][$activeSlave.earwear = "hearing aids",$cash -= $modCost]]
+	| [[Muffling ear plugs|Salon][$activeSlave.earwear = "muffling ear plugs",$cash -= $modCost]]
+	| [[Deafening ear plugs|Salon][$activeSlave.earwear = "deafening ear plugs",$cash -= $modCost]]
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;
+<</if>>
+
+/*End ear check */
 
 /* HAIR */
 
 <br><br>
 
 <<if $activeSlave.bald != 1>>
-	$possessiveCap hair is $activeSlave.hColor.
+	$His hair is $activeSlave.hColor.
 	<<if $activeSlave.origHColor != $activeSlave.hColor>>
 		[[Restore natural color|Salon][$activeSlave.hColor = $activeSlave.origHColor]] or //choose a new one://
 	<<else>>
@@ -194,10 +248,10 @@
 		[[Dye her hair|Salon][$activeSlave.hColor = ($primaryHairColor + $secondaryHairColor),$cash -= $modCost, $primaryHairColor = 0, $secondaryHairColor = ""]] $primaryHairColor $secondaryHairColor now?
 	<</if>>
 
-	<br><br>$possessiveCap $activeSlave.hStyle hair is <<= lengthToEitherUnit($activeSlave.hLength)>> long. //General hairstyles will conform to hair length and clothing choices.//
+	<br><br>$His $activeSlave.hStyle hair is <<= lengthToEitherUnit($activeSlave.hLength)>> long. //General hairstyles will conform to hair length and clothing choices.//
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
 	<<if $activeSlave.hLength > 1>>
-		Style $possessive hair:
+		Style $his hair:
 		[[Neat|Salon][$activeSlave.hStyle = "neat",$cash -= $modCost]]
 		 | [[Up|Salon][$activeSlave.hStyle = "up",$cash -= $modCost]]
 		 | [[In a ponytail|Salon][$activeSlave.hStyle = "ponytail",$cash -= $modCost]]
@@ -215,19 +269,19 @@
 		 | [[Afro|Salon][$activeSlave.hStyle = "afro",$cash -= $modCost]]
 		 | [[Shaved sides|Salon][$activeSlave.hStyle = "strip",$cash -= $modCost]]
 	<<else>>
-		//$possessiveCap hair is too short to style meaningfully//
+		//$His hair is too short to style meaningfully//
 	<</if>>
 	
 	<<if $activeSlave.hLength > 1>>
 		<br>&nbsp;&nbsp;&nbsp;&nbsp;
-		Cut and style $possessive hair:
+		Cut and style $his hair:
 		 [[Shaved|Salon][$activeSlave.hStyle = "shaved",$activeSlave.hLength = 0,$cash -= $modCost]]
 		 | [[Trimmed short|Salon][$activeSlave.hStyle = "trimmed",$activeSlave.hLength = 10,$cash -= $modCost]]
 		 | [[Buzzcut|Salon][$activeSlave.hStyle = "buzzcut",$activeSlave.hLength = 1,$cash -= $modCost]]
 	<</if>>
 		
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
-	Cut or lengthen $possessive hair:
+	Cut or lengthen $his hair:
 	<<if $activeSlave.hLength > 5>>
 		[[Very short|Salon][$activeSlave.hLength = 5,$cash -= $modCost]]
 	<</if>>
@@ -250,7 +304,7 @@
 	<</if>>
 	
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
-	Have $possessive hair carefully maintained at its current length:
+	Have $his hair carefully maintained at its current length:
 	<<if $activeSlave.haircuts == 1>>
 		[[Cease maintenance|Salon][$activeSlave.haircuts = 0]]
 	<<else>>
@@ -258,10 +312,10 @@
 	<</if>>
 <<else>>
 	<<if $activeSlave.hStyle == "bald">>
-		$pronounCap is completely bald.
+		$He is completely bald.
 		<br>&nbsp;&nbsp;&nbsp;&nbsp;
 	<<else>>
-		$possessiveCap current wig is $activeSlave.hColor. 
+		$His current wig is $activeSlave.hColor. 
 		<<if $activeSlave.origHColor == "bald" && $activeSlave.hStyle != "bald">>
 			[[Remove wig|Salon][$activeSlave.hStyle = "bald",$activeSlave.hLength = 0,$cash -= $modCost]] or //choose a new one://
 		<<else>>
@@ -314,13 +368,13 @@
 		
 		<<if $primaryHairColor != 0>>
 			<br>&nbsp;&nbsp;&nbsp;&nbsp;
-			[[Change|Salon][$activeSlave.hColor = ($primaryHairColor + $secondaryHairColor),$cash -= $modCost, $primaryHairColor = 0, $secondaryHairColor = ""]] $possessive wig color to $primaryHairColor $secondaryHairColor
+			[[Change|Salon][$activeSlave.hColor = ($primaryHairColor + $secondaryHairColor),$cash -= $modCost, $primaryHairColor = 0, $secondaryHairColor = ""]] $his wig color to $primaryHairColor $secondaryHairColor
 		<</if>>
 	<</if>>
 
 	<<if $activeSlave.hStyle != "bald">>
 		<br><br>
-		$possessiveCap $activeSlave.hStyle wig is <<= lengthToEitherUnit($activeSlave.hLength)>> long. 
+		$His $activeSlave.hStyle wig is <<= lengthToEitherUnit($activeSlave.hLength)>> long. 
 		
 		//General hairstyles will conform to hair length and clothing choices.//
 		
@@ -335,7 +389,7 @@
 		<<if $activeSlave.hLength != 120>>[[lengthToEitherUnit(120)|Salon][$activeSlave.hLength = 120,$cash -= $modCost]]<</if>>
 		<<if $activeSlave.hLength != 150>>[[lengthToEitherUnit(150)|Salon][$activeSlave.hLength = 150,$cash -= $modCost]]<</if>>
 	<<else>>
-		$pronounCap is not wearing a wig.
+		$He is not wearing a wig.
 	<</if>>
 	<br><br>&nbsp;&nbsp;&nbsp;&nbsp;
 	<<if $activeSlave.hStyle != "bald">>	
@@ -356,7 +410,6 @@
 	 | [[Afro|Salon][$activeSlave.hStyle = "afro",$cash -= $modCost]]
 <</if>>
 
-
 /* MAKEUP */
 
 <br><br>
@@ -378,7 +431,6 @@ Apply makeup:
 [[Metallic|Salon][$activeSlave.makeup = 7,$cash -= $modCost]]
 | [[Metallic, color-coordinate with hair|Salon][$activeSlave.makeup = 8,$cash -= $modCost]]
 
-
 /* NAILS */
 
 <br><br>
@@ -401,7 +453,6 @@ Treat nails:
 | [[Metallic, color-coordinate with hair|Salon][$activeSlave.nails = 9,$cash -= $modCost]]
 <</if>>
 
-
 /* SKIN */
 
 <<set $tannableSkin = ["natural", "lightened", "white", "fair", "pale", "light", "extremely pale"]>>
@@ -410,9 +461,8 @@ Treat nails:
 <<set $darkenableSkin = ["natural", "lightened", "white", "fair", "pale", "light", "extremely pale", "light olive", "tanned", "brown", "dark brown"]>>
 <<set $dyedSkin = ["dyed red", "dyed green", "dyed blue", "dyed pink", "dyed gray", "tiger striped", "camouflage patterned"]>>
 
-
 <br><br>
-$possessiveCap skin is $activeSlave.skin.
+$His skin is $activeSlave.skin.
 
 <<if ($dyedSkin.indexOf($activeSlave.skin) != -1)>>
 	[[Remove coloring|Salon][$activeSlave.skin = $activeSlave.origSkin,$cash -= $modCost]]
@@ -458,33 +508,32 @@ Dye or paint:
 
 <<if ($activeSlave.markings == "beauty mark")>>
 	<br><br>
-	$pronounCap has a prominent mole on $possessive face, which
+	$He has a prominent mole on $his face, which
 	<<if $activeSlave.face > 40>>
-	qualifies as a beauty mark and enhances $possessive attractiveness due to $possessive facial beauty.
+	qualifies as a beauty mark and enhances $his attractiveness due to $his facial beauty.
 	<<elseif $activeSlave.face < -10>>
-	makes $possessive even less attractive.
+	makes $his even less attractive.
 	<<else>>
-	qualifies as a beauty mark since $pronoun's pretty, having no significant impact on $possessive beauty.
+	qualifies as a beauty mark since $he's pretty, having no significant impact on $his beauty.
 	<</if>>
 	[[Remove it|Salon][$activeSlave.markings = "none",$cash -= $modCost]]
 <</if>>
 <<if ($activeSlave.markings == "birthmark")>>
 	<br><br>
-	$pronounCap has a large birthmark, which
+	$He has a large birthmark, which
 	<<if $activeSlave.prestige > 0 || $activeSlave.pornPrestige > 1>>
-	enhances $possessive attractiveness due to $possessive prestige.
+	enhances $his attractiveness due to $his prestige.
 	<<else>>
-	detracts from $possessive attractiveness.
+	detracts from $his attractiveness.
 	<</if>>
 	[[Bleach it|Salon][$activeSlave.markings = "none",$cash -= $modCost]]
 <</if>>
 
-
 /* PUBIC HAIR */
 
 <<if $activeSlave.pubicHStyle != "bald" && $activeSlave.pubicHStyle != "hairless" && $activeSlave.physicalAge >= 12>>
 	
-	<br><br>$possessiveCap $activeSlave.pubicHStyle pubic hair
+	<br><br>$His $activeSlave.pubicHStyle pubic hair
 	<<if $activeSlave.pubicHStyle == "waxed">>
 		would be $activeSlave.pubicHColor if present.
 	<<else>>
@@ -495,7 +544,7 @@ Dye or paint:
 	<</if>>
 	
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
-	Dye $possessive pubic hair:
+	Dye $his pubic hair:
 		[[Blonde|Salon][$activeSlave.pubicHColor = "blonde",$cash -= $modCost]]
 		| [[Golden|Salon][$activeSlave.pubicHColor = "golden",$cash -= $modCost]]
 		| [[Platinum blonde|Salon][$activeSlave.pubicHColor = " platinum blonde",$cash -= $modCost]]
@@ -525,7 +574,7 @@ Dye or paint:
 		| [[Neon pink|Salon][$activeSlave.pubicHColor = "neon pink",$cash -= $modCost]]
 
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
-	Style $possessive pubic hair:
+	Style $his pubic hair:
 		[[Waxed|Salon][$activeSlave.pubicHStyle = "waxed",$cash -= $modCost]]
 		 | [[Landing strip|Salon][$activeSlave.pubicHStyle = "in a strip",$cash -= $modCost]]
 		 | [[Neat|Salon][$activeSlave.pubicHStyle = "neat",$cash -= $modCost]]
@@ -534,12 +583,12 @@ Dye or paint:
 		 | [[Very Bushy|Salon][$activeSlave.pubicHStyle = "very bushy",$cash -= $modCost]]
 	
 <<else>>
-	<br><br>$possessiveCap groin is completely hairless.
+	<br><br>$His groin is completely hairless.
 <</if>>
 
 <<if $activeSlave.underArmHStyle != "bald" && $activeSlave.underArmHStyle != "hairless" && $activeSlave.physicalAge >= 12>>
 
-	<br><br>$possessiveCap $activeSlave.underArmHStyle underarm hair
+	<br><br>$His $activeSlave.underArmHStyle underarm hair
 	<<if $activeSlave.underArmHStyle == "waxed">>
 		would be $activeSlave.underArmHColor if present.
 	<<else>>
@@ -549,7 +598,7 @@ Dye or paint:
 		[[Match the curtains?|Salon][$activeSlave.underArmHColor = $activeSlave.hColor,$cash -= $modCost]]
 	<</if>>
 
-	<br>&nbsp;&nbsp;&nbsp;&nbsp;Dye $possessive armpit hair:
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;Dye $his armpit hair:
 		[[Blonde|Salon][$activeSlave.underArmHColor = "blonde",$cash -= $modCost]]
 		| [[Golden|Salon][$activeSlave.underArmHColor = "golden",$cash -= $modCost]]
 		| [[Platinum blonde|Salon][$activeSlave.underArmHColor = " platinum blonde",$cash -= $modCost]]
@@ -579,13 +628,12 @@ Dye or paint:
 		| [[Neon pink|Salon][$activeSlave.underArmHColor = "neon pink",$cash -= $modCost]]
 
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
-	Style $possessive armpit hair:
+	Style $his armpit hair:
 		[[Waxed|Salon][$activeSlave.underArmHStyle = "waxed",$cash -= $modCost]]
 		 | [[Shaved|Salon][$activeSlave.underArmHStyle = "shaved",$cash -= $modCost]]
 		 | [[Neat|Salon][$activeSlave.underArmHStyle = "neat",$cash -= $modCost]]
 		 | [[Bushy|Salon][$activeSlave.underArmHStyle = "bushy",$cash -= $modCost]]
 
 <<else>>
-	<br><br>$possessiveCap underarms are completely hairless.
+	<br><br>$His underarms are completely hairless.
 <</if>>
-
diff --git a/src/uncategorized/seCustomSlaveDelivery.tw b/src/uncategorized/seCustomSlaveDelivery.tw
index 9e454d426929ba60e1cb0c2574ad002bf90071bf..f85d3f509285f00a9e56b1e055bb8fb9548c8a38 100644
--- a/src/uncategorized/seCustomSlaveDelivery.tw
+++ b/src/uncategorized/seCustomSlaveDelivery.tw
@@ -172,6 +172,7 @@
 <<set $activeSlave.intelligence = $customSlave.intelligence>>
 <<set $activeSlave.intelligenceImplant = $customSlave.intelligenceImplant>>
 <<set $activeSlave.eyes = $customSlave.eyes>>
+<<set $activeSlave.hears = $customSlave.hears>>
 <<set $activeSlave.amp = $customSlave.amp>>
 <<set $activeSlave.weekAcquired = $week>>
 <<set $activeSlave.origin = "You purchased her by special order.">>
diff --git a/src/uncategorized/slaveShelter.tw b/src/uncategorized/slaveShelter.tw
index e3d88dd08f6c214a39f5699f0b12f2749f88235f..98288f63d37a536f686b3166da94f940163c8fcb 100644
--- a/src/uncategorized/slaveShelter.tw
+++ b/src/uncategorized/slaveShelter.tw
@@ -15,7 +15,7 @@ You contact the Slave Shelter to review the profile of the slave the Shelter is
 <<set _possibleOrigins = []>>
 <<set _possibleOrigins.push("broken")>>
 <<if $seeExtreme == 1>>
-	<<set _possibleOrigins.push("amputee", "blind")>>
+	<<set _possibleOrigins.push("amputee", "blind", "deaf")>>
 	<<if random(1,99) < $seeDicks>>
 		<<set _possibleOrigins.push("cannibal victim male")>>
 	<<else>>
@@ -86,6 +86,20 @@ You contact the Slave Shelter to review the profile of the slave the Shelter is
 	<<set $shelterSlave.behavioralFlaw = "hates men">>
 	<<set $shelterSlave.sexualFlaw = "hates oral">>
 	<<set $shelterSlave.canRecruit = 0>>
+<<case "deaf">>
+ 	<<set $activeSlaveOneTimeMinAge = $minimumSlaveAge>>
+ 	<<set $activeSlaveOneTimeMaxAge = 22>>
+	<<include "Generate New Slave">>
+	<<set $shelterSlave = $activeSlave>>
+	<<set $shelterSlave.origin = "Her owner purposely deafened her by piercing her eardrums with knitting needles.">>
+	<<set $shelterSlave.career = "a slave">>
+	<<set $shelterSlave.hears = -2>>
+	<<set $shelterSlave.devotion = random(-100,-90)>>
+	<<set $shelterSlave.trust = random(-100,-90)>>
+	<<set $shelterSlave.health = random(-80,-60)>>
+	<<set $shelterSlave.behavioralFlaw = "hates men">>
+	<<set $shelterSlave.sexualFlaw = "hates oral">>
+	<<set $shelterSlave.canRecruit = 0>>
 <<case "broken womb">>
  	<<set $activeSlaveOneTimeMinAge = 6>>
  	<<set $activeSlaveOneTimeMaxAge = 22>>
diff --git a/src/utility/assayWidgets.tw b/src/utility/assayWidgets.tw
index bc2c01f000ed3888d35a2d13eb1ad959ad66ecf7..284009b09e38fcabd905bc702516ec9c2f0eebf1 100644
--- a/src/utility/assayWidgets.tw
+++ b/src/utility/assayWidgets.tw
@@ -1233,8 +1233,8 @@
 <</if>>
 
 <<if !canHear($args[0])>>
-	<<set $deadliness -= 8>>
-<<elseif ($args[0].hears == -1 && !["corrective glasses", "corrective contacts"].includes($args[0].earwear)) || ($args[0].hears == 0 && ["blurring glasses", "blurring contacts"].includes($args[0].earwear))>>
+	<<set $deadliness -= 5>>
+<<elseif ($args[0].hears == -1 && !["hearing aids"].includes($args[0].earwear)) || ($args[0].hears == 0 && ["muffling ear plugs"].includes($args[0].earwear))>>
 	<<set $deadliness -= 1>>
 <</if>>
 
diff --git a/src/utility/descriptionWidgetsFlesh.tw b/src/utility/descriptionWidgetsFlesh.tw
index 8c6b3e5321730f539b1b49e27835f91de935092d..ed5348d8f627402b495638a8bd84571e53744f69 100644
--- a/src/utility/descriptionWidgetsFlesh.tw
+++ b/src/utility/descriptionWidgetsFlesh.tw
@@ -4641,11 +4641,8 @@ $He's got a
 	<</if>>
 <</if>>
 
-
-
 <</widget>>
 
-
 <<widget "eyeDescription">>
 <<if $activeSlave.eyes == -2>>
 	<<if $activeSlave.eyeColor != "empty">>
@@ -4747,6 +4744,17 @@ $He's got a
 <</if>>
 <</widget>>
 
+<<widget "earDescription">>
+/* ear shape description here */
+<<if $activeSlave.hears > -1>>
+	$He has no major hearing problems,
+<<elseif $activeSlave.hears == -1>>
+	$His hearing is noticeably impaired,
+<<elseif $activeSlave.hears < -1>>
+	$He is completely deaf,
+<</if>>
+but this isn't obvious just by looking at $his ears.
+<</widget>>
 
 <<widget "faceDescription">>
 
@@ -4755,99 +4763,99 @@ $His
 <<switch $activeSlave.faceShape>>
 <<case "masculine">>
 	<<if $activeSlave.face < -95>>
-	so ugly and masculine that $his designation as a slave girl is a mockery.
+		so ugly and masculine that $his designation as a slave girl is a mockery.
 	<<elseif $activeSlave.face < -40>>
-	ugly and masculine, making $him a poor slave girl by appearance.
+		ugly and masculine, making $him a poor slave girl by appearance.
 	<<elseif $activeSlave.face < -10>>
-	unattractively masculine.
+		unattractively masculine.
 	<<elseif ($activeSlave.face <= 10)>>
-	masculine, but not entirely unappealing.
+		masculine, but not entirely unappealing.
 	<<elseif ($activeSlave.face <= 40)>>
-	attractively masculine.
+		attractively masculine.
 	<<elseif ($activeSlave.face <= 95)>>
-	quite handsome in a masculine way.
+		quite handsome in a masculine way.
 	<<else>>
-	the height of masculine handsomeness.
+		the height of masculine handsomeness.
 	<</if>>
 <<case "androgynous">>
 	<<if $activeSlave.face < -95>>
-	disturbingly androgynous and terribly ugly.
+		disturbingly androgynous and terribly ugly.
 	<<elseif $activeSlave.face < -40>>
-	ugly and androgynous; $he has neither masculine nor feminine appeal.
+		ugly and androgynous; $he has neither masculine nor feminine appeal.
 	<<elseif $activeSlave.face < -10>>
-	strangely androgynous, and rather unattractive.
+		strangely androgynous, and rather unattractive.
 	<<elseif ($activeSlave.face <= 10)>>
-	strangely androgynous.
+		strangely androgynous.
 	<<elseif ($activeSlave.face <= 40)>>
-	androgynous, and attractive enough that this ambiguity is interesting.
+		androgynous, and attractive enough that this ambiguity is interesting.
 	<<elseif ($activeSlave.face <= 95)>>
-	gorgeously androgynous in a complex way that captures the eye.
+		gorgeously androgynous in a complex way that captures the eye.
 	<<else>>
-	so gorgeously androgynous that $he tends to induce sexual confusion.
+		so gorgeously androgynous that $he tends to induce sexual confusion.
 	<</if>>
 <<case "cute">>
 	<<if $activeSlave.face < -95>>
-	very ugly, yet somehow cute; $he's so unattractive that $he inspires pity.
+		very ugly, yet somehow cute; $he's so unattractive that $he inspires pity.
 	<<elseif $activeSlave.face < -40>>
-	ugly, but cute, with a pitiable appeal.
+		ugly, but cute, with a pitiable appeal.
 	<<elseif $activeSlave.face < -10>>
-	not attractive, but is appealingly cute.
+		not attractive, but is appealingly cute.
 	<<elseif ($activeSlave.face <= 10)>>
-	merely average, but is appealingly cute.
+		merely average, but is appealingly cute.
 	<<elseif ($activeSlave.face <= 40)>>
-	both attractive and appealingly cute.
+		both attractive and appealingly cute.
 	<<elseif ($activeSlave.face <= 95)>>
-	beautiful, yet somehow also approachably cute.
+		beautiful, yet somehow also approachably cute.
 	<<else>>
-	an impossibly perfect combination of beauty and girl-next-door cuteness.
+		an impossibly perfect combination of beauty and girl-next-door cuteness.
 	<</if>>
 <<case "sensual">>
 	<<if $activeSlave.face < -95>>
-	very ugly, yet naturally slutty, promising a decent fuck despite its appearance.
+		very ugly, yet naturally slutty, promising a decent fuck despite its appearance.
 	<<elseif $activeSlave.face < -40>>
-	ugly, but also slutty, promising a good fuck despite its appearance.
+		ugly, but also slutty, promising a good fuck despite its appearance.
 	<<elseif $activeSlave.face < -10>>
-	not attractive, but it has a certain sensual appeal.
+		not attractive, but it has a certain sensual appeal.
 	<<elseif ($activeSlave.face <= 10)>>
-	merely average, but undeniably sensual.
+		merely average, but undeniably sensual.
 	<<elseif ($activeSlave.face <= 40)>>
-	both attractive and naturally sultry.
+		both attractive and naturally sultry.
 	<<elseif ($activeSlave.face <= 95)>>
-	both beautiful and sultry, bringing sex to mind naturally.
+		both beautiful and sultry, bringing sex to mind naturally.
 	<<else>>
-	very beautiful in a consummately sexual way.
+		very beautiful in a consummately sexual way.
 	<</if>>
 <<case "exotic">>
 	<<if $activeSlave.face < -95>>
-	very ugly and unusual, a real tragedy in flesh.
+		very ugly and unusual, a real tragedy in flesh.
 	<<elseif $activeSlave.face < -40>>
-	ugly and unusual, a real misfortune.
+		ugly and unusual, a real misfortune.
 	<<elseif $activeSlave.face < -10>>
-	unattractive, and distinctive in its unattractiveness.
+		unattractive, and distinctive in its unattractiveness.
 	<<elseif ($activeSlave.face <= 10)>>
-	quite average, but not uninteresting.
+		quite average, but not uninteresting.
 	<<elseif ($activeSlave.face <= 40)>>
-	attractive in an exotic and interesting way.
+		attractive in an exotic and interesting way.
 	<<elseif ($activeSlave.face <= 95)>>
-	exotic and beautiful, capable of catching the eye and keeping its gaze.
+		exotic and beautiful, capable of catching the eye and keeping its gaze.
 	<<else>>
-	very beautiful and exotic, almost to the point of alien fascination.
+		very beautiful and exotic, almost to the point of alien fascination.
 	<</if>>
 <<default>>
 	<<if $activeSlave.face < -95>>
-	very ugly.
+		very ugly.
 	<<elseif $activeSlave.face < -40>>
-	quite ugly.
+		quite ugly.
 	<<elseif $activeSlave.face < -10>>
-	unattractive.
+		unattractive.
 	<<elseif ($activeSlave.face <= 10)>>
-	average and conventionally feminine.
+		average and conventionally feminine.
 	<<elseif ($activeSlave.face <= 40)>>
-	conventionally attractive.
+		conventionally attractive.
 	<<elseif ($activeSlave.face <= 95)>>
-	conventionally beautiful.
+		conventionally beautiful.
 	<<else>>
-	the height of conventional feminine beauty.
+		the height of conventional feminine beauty.
 	<</if>>
 <</switch>>@@
 <<if $activeSlave.weight > 190>>
@@ -4883,7 +4891,7 @@ $His
 		<<elseif ($activeSlave.face <= 95)>>
 		$He has a beauty mark that adds to $his distinctiveness.
 		<<else>>
-		$He has a beauty mark that makes $his really memorable.
+		$He has a beauty mark that makes $him really memorable.
 		<</if>>
 	<</if>>
 <</if>>
@@ -5026,10 +5034,8 @@ $He has
 	<</if>>
 <</if>>
 
-
 <</widget>>
 
-
 <<widget "BellyDescription">>
 
 <<set $bellyAccessory = $activeSlave.bellyAccessory>>
diff --git a/src/utility/descriptionWidgetsStyle.tw b/src/utility/descriptionWidgetsStyle.tw
index 1ba43ec90efd32755456a2eedd62716a18cf8134..9feb126a69dd456a0d4ca30b7f32538f06351f22 100644
--- a/src/utility/descriptionWidgetsStyle.tw
+++ b/src/utility/descriptionWidgetsStyle.tw
@@ -2650,13 +2650,38 @@ $His
 					$He is @@.red;blind@@, and moves very carefully as a result.
 			<</if>>
 		<</if>> /* CLOSES EYEWEAR */
+		<<if ($activeSlave.earwear == "hearing aids") || ($activeSlave.earwear == "muffling ear plugs") || ($activeSlave.earwear == "deafening ear plugs")>>
+			In $his ears, $he wears
+			<<if $activeSlave.eyewear == "hearing aids">>
+				a pair of hearing aids,
+				<<if $activeSlave.hears > -1>>
+				<<elseif $activeSlave.hears == -1>>
+				<<elseif $activeSlave.hears < -1>>
+				<</if>>
+			<<elseif $activeSlave.eyewear == "muffling ear plugs">>
+				a pair of small foam ear plugs,
+				<<if $activeSlave.hears > -1>>
+				<<elseif $activeSlave.hears == -1>>
+				<<elseif $activeSlave.hears < -1>>
+				<</if>>
+			<<elseif $activeSlave.eyewear == "deafening ear plugs">>
+				a pair of large silicone ear plugs,
+				<<if $activeSlave.hears > -1>>
+				<<elseif $activeSlave.hears == -1>>
+				<<elseif $activeSlave.hears < -1>>
+				<</if>>
+			<</if>>
+		<<else>>
+			<<if $activeSlave.hears > -1>>
+			<<elseif $activeSlave.hears == -1>>
+			<<elseif $activeSlave.hears < -1>>
+			<</if>>
+		<</if>>
 	<<else>>
 		Its face is featurelessly obscured by the Fuckdoll suit from the top of its head down to its face hole.
 	<</if>>
 <</widget>>
 
-
-
 <<widget "collarDescription">>
 	<<switch $activeSlave.collar>>
 	<<case "uncomfortable leather">>
diff --git a/src/utility/slaveCreationWidgets.tw b/src/utility/slaveCreationWidgets.tw
index 630d379ee9476cbc7d82fd2ee07241a9b6b525cb..25aedf8283353f97543f46b20ef0561ebe0c45b4 100644
--- a/src/utility/slaveCreationWidgets.tw
+++ b/src/utility/slaveCreationWidgets.tw
@@ -2676,7 +2676,7 @@
 	<<set $activeSlave.health = random(-99,0)>>
 	<<set $activeSlave.weight = random(-100,0)>>
 	<<set $activeSlave.eyes = either(-2, -1, -1, -1, -1, 1, 1, 1)>>
-	<<set $activeSlave.hears = either(-2, -1, -1, -1, -1, 1, 1, 1)>>
+	<<set $activeSlave.hears = either(-2, -1, -1, -1, -1, 0, 0, 0)>>
 	<<if $seeExtreme == 1>>
 		<<set $activeSlave.amp = either(0, 0, 0, 0, 0, 0, 1, 1, 1)>>
 	<</if>>