diff --git a/SanityCheck.jar b/SanityCheck.jar
index 478417de473b6dd0de5575eef4d474e2ef3d7073..f19e52f690973f356affb974151449cdce45adcc 100644
Binary files a/SanityCheck.jar and b/SanityCheck.jar differ
diff --git a/devNotes/VersionChangeLog-Premod+LoliMod.txt b/devNotes/VersionChangeLog-Premod+LoliMod.txt
index dcbfa59a4fe8531ce169f16315e6cd6d2ccb5cc9..50e7a259afe2b71c73c12e2ba7c4abf732b9bcf5 100644
--- a/devNotes/VersionChangeLog-Premod+LoliMod.txt
+++ b/devNotes/VersionChangeLog-Premod+LoliMod.txt
@@ -1,13 +1,18 @@
 Pregmod
 
-0.10.7.1-2.2.x
+0.10.7.1-2.3.x
 
+	0
 	-player can now be impregnated during the futanari sister orgy
 	-added tracking for futanari sister impregnation
 	-player medicine and trading skill now more useful
+	-easier to passively gain slaving skill
+	-UI changes
 	-fixes
 	-code cleaning
 
+0.10.7.1-2.2.x
+
 03/15/2019
 
 	5
diff --git a/devNotes/twine CSS b/devNotes/twine CSS
index e3da430ae7e5616908919995f033dfb7add7508c..39e646cedfe25ebed9c196a0f0c18c6c75cd2f93 100644
--- a/devNotes/twine CSS	
+++ b/devNotes/twine CSS	
@@ -656,7 +656,6 @@ div.tab button.active {
 	border: #555 solid 0.5px;
 	border-top-width: 0;
 	vertical-align: top;
-	background: linear-gradient(transparent,#222);
 	-moz-user-select: none;
 	min-width: 79px; /* 80px - 1px for border */
 	display: inline-block;
@@ -666,6 +665,7 @@ div.tab button.active {
 .optionComment {
 	vertical-align: top;
 	color: gray;
+	padding-left: 10px;
 }
 
 /* But don't add the | after the last one */
@@ -688,11 +688,11 @@ div.tab button.active {
 }
 
 .optionMacroOption:hover {
-	background: linear-gradient(#2F2F2F,#111);
+	background: #2F2F2F;
 }
 
 .optionMacroSelected {
-	background: linear-gradient(#2F2F2F,#111);
+	background: #2F2F2F;
 	padding: 0 10px;
 	min-width: 80px;
 	cursor: pointer;
@@ -705,8 +705,8 @@ div.tab button.active {
 }
 
 .optionValue input {
-	padding: 3px;
-	background: linear-gradient(transparent,#222);
+	padding: 3px 3px 3px 10px;
+	background: transparent;
 	border: #555 solid 0.5px;
 	border-top-width: 0;
 	min-width: unset;
diff --git a/devTools/javaSanityCheck/htmlTags b/devTools/javaSanityCheck/htmlTags
index 466a9b301e715f5b896bd84c38941bf61c4ec985..d6797ca12f38ec785c0e45c7f4df696643408c0e 100644
--- a/devTools/javaSanityCheck/htmlTags
+++ b/devTools/javaSanityCheck/htmlTags
@@ -29,7 +29,7 @@ h4;1
 hr;0
 html;1
 i;1
-img;1
+img;0
 input;0
 li;1
 option;1
diff --git a/devTools/javaSanityCheck/info.txt b/devTools/javaSanityCheck/info.txt
new file mode 100644
index 0000000000000000000000000000000000000000..e949bd8d03f785569f824dbae27c9c282bcb8014
--- /dev/null
+++ b/devTools/javaSanityCheck/info.txt
@@ -0,0 +1,2 @@
+Full sources for easy import into IDE can be found here:
+https://gitgud.io/Arkerthan/twine-sanitycheck
diff --git a/devTools/javaSanityCheck/src/DisallowedTagException.java b/devTools/javaSanityCheck/src/DisallowedTagException.java
index cd479fbdf5f9c8b42a9271b8c0049cba10bcb72a..12d5dfb2974506d0b3a0be713f3b5cf7217944ba 100644
--- a/devTools/javaSanityCheck/src/DisallowedTagException.java
+++ b/devTools/javaSanityCheck/src/DisallowedTagException.java
@@ -1,5 +1,8 @@
 package org.arkerthan.sanityCheck;
 
+/**
+ * @author Arkerthan
+ */
 public class DisallowedTagException extends RuntimeException {
 
 	public DisallowedTagException(String tag) {
diff --git a/devTools/javaSanityCheck/src/Main.java b/devTools/javaSanityCheck/src/Main.java
index 84c471d2148d57206c18d5ac8a217f67bac07d21..72e0e7cfdd42526b36868ec9f431af53ef4eb9f2 100644
--- a/devTools/javaSanityCheck/src/Main.java
+++ b/devTools/javaSanityCheck/src/Main.java
@@ -14,6 +14,7 @@ import java.util.*;
 
 /**
  * @author Arkerthan
+ * @version 1.0
  */
 public class Main {
 
@@ -311,6 +312,8 @@ public class Main {
 			case '/':
 				stack.push(new CommentElement(currentLine, currentPosition));
 				break;
+			//case '(':
+			//	stack.push(new BracketElement(currentLine, currentPosition));
 		}
 	}
 
diff --git a/devTools/javaSanityCheck/src/SyntaxError.java b/devTools/javaSanityCheck/src/SyntaxError.java
index c30e5fbc101c558ff3cabe669d38c0e89f50e3f7..ccb49ccf8882a8f10dbbf81e9d78128588d10c7c 100644
--- a/devTools/javaSanityCheck/src/SyntaxError.java
+++ b/devTools/javaSanityCheck/src/SyntaxError.java
@@ -1,5 +1,8 @@
 package org.arkerthan.sanityCheck;
 
+/**
+ * @author Arkerthan
+ */
 public class SyntaxError extends Exception {
 	private String file;
 	private int line, position;
diff --git a/devTools/javaSanityCheck/src/Tag.java b/devTools/javaSanityCheck/src/Tag.java
index 5c3c92651a71beb8a4e3cba73d1eb64238fc9908..025cef72c10fda5d3dbe3d45e2af1b907f6841df 100644
--- a/devTools/javaSanityCheck/src/Tag.java
+++ b/devTools/javaSanityCheck/src/Tag.java
@@ -1,5 +1,8 @@
 package org.arkerthan.sanityCheck;
 
+/**
+ * @author Arkerthan
+ */
 public class Tag {
 	public final String tag;
 	public final boolean single;
diff --git a/devTools/javaSanityCheck/src/TagSearchTree.java b/devTools/javaSanityCheck/src/TagSearchTree.java
index 71e89ec769ff658b246886a179976055f2633709..68165866594478e56b990f822d30edddacf14eef 100644
--- a/devTools/javaSanityCheck/src/TagSearchTree.java
+++ b/devTools/javaSanityCheck/src/TagSearchTree.java
@@ -3,10 +3,11 @@ package org.arkerthan.sanityCheck;
 import java.util.List;
 
 /**
+ * @param <E> Tag class to be stored
+ * @author Arkerthan
+ * <p>
  * Tag SearchTree stores Tags in an alphabetical search tree.
  * Once created the search tree can't be changed anymore.
- *
- * @param <E> Tag class to be stored
  */
 public class TagSearchTree<E extends Tag> {
 	private static final int SIZE = 128;
diff --git a/devTools/javaSanityCheck/src/UnknownStateException.java b/devTools/javaSanityCheck/src/UnknownStateException.java
index 80dbe598682d23875efe5517170f4f1c91a96246..348a275e20141a6b0fdaefda4b667ca821d305cc 100644
--- a/devTools/javaSanityCheck/src/UnknownStateException.java
+++ b/devTools/javaSanityCheck/src/UnknownStateException.java
@@ -1,5 +1,8 @@
 package org.arkerthan.sanityCheck;
 
+/**
+ * @author Arkerthan
+ */
 public class UnknownStateException extends RuntimeException {
 
 	public UnknownStateException(int state) {
diff --git a/devTools/javaSanityCheck/src/element/AngleBracketElement.java b/devTools/javaSanityCheck/src/element/AngleBracketElement.java
index e129ee20cf401a23d83e520474a4aaa5a1b69991..18ef66c8c33f8918a6da338fd8c025d0698ba2a8 100644
--- a/devTools/javaSanityCheck/src/element/AngleBracketElement.java
+++ b/devTools/javaSanityCheck/src/element/AngleBracketElement.java
@@ -5,6 +5,9 @@ import org.arkerthan.sanityCheck.*;
 import java.util.Arrays;
 import java.util.List;
 
+/**
+ * @author Arkerthan
+ */
 public class AngleBracketElement extends Element {
 	private static final List<String> logicTags = Arrays.asList("if", "elseif", "else", "switch", "case", "default");
 	private int state = 0;
@@ -47,15 +50,13 @@ public class AngleBracketElement extends Element {
 					case '<':
 						state = 1;
 						return 1;
-					case '>':
-						throw new SyntaxError("Empty Statement?", 2);
 					case '/':
 						state = -9;
 						return 1;
+					case '>':// empty <>
 					case ' ':// assume comparison
-					case '=':// "
-						return 2;
-					case '3'://a heart: <3
+					case '='://	"		"
+					case '3':// a heart: <3
 						return 2;
 					default:
 						try {
@@ -311,7 +312,7 @@ public class AngleBracketElement extends Element {
 	@Override
 	public String getShortDescription() {
 		StringBuilder builder = new StringBuilder();
-		builder.append('[').append(line).append(":").append(pos).append("] ");
+		builder.append(getPositionAsString()).append(" ");
 		switch (state) {
 			case 0:
 				builder.append("<");
diff --git a/devTools/javaSanityCheck/src/element/AtElement.java b/devTools/javaSanityCheck/src/element/AtElement.java
index 168e340a4326b24c0dff912c64d25ec5042d6fe5..f6e39a6ddce230dab16b42b52fbd14b054d20c52 100644
--- a/devTools/javaSanityCheck/src/element/AtElement.java
+++ b/devTools/javaSanityCheck/src/element/AtElement.java
@@ -3,6 +3,9 @@ package org.arkerthan.sanityCheck.element;
 import org.arkerthan.sanityCheck.SyntaxError;
 import org.arkerthan.sanityCheck.UnknownStateException;
 
+/**
+ * @author Arkerthan
+ */
 public class AtElement extends Element {
 	private int state = 0;
 	// 0 = @
@@ -77,7 +80,7 @@ public class AtElement extends Element {
 	@Override
 	public String getShortDescription() {
 		StringBuilder builder = new StringBuilder();
-		builder.append(line).append(":").append(pos).append(" ");
+		builder.append(getPositionAsString()).append(" ");
 		switch (state) {
 			case 0:
 				builder.append("@");
diff --git a/devTools/javaSanityCheck/src/element/BracketElement.java b/devTools/javaSanityCheck/src/element/BracketElement.java
new file mode 100644
index 0000000000000000000000000000000000000000..b9848941653e6cb3715e60ac7342a1d087e0ebba
--- /dev/null
+++ b/devTools/javaSanityCheck/src/element/BracketElement.java
@@ -0,0 +1,28 @@
+package org.arkerthan.sanityCheck.element;
+
+import org.arkerthan.sanityCheck.SyntaxError;
+
+/**
+ * @author Arkerthan
+ */
+public class BracketElement extends Element {
+    //int state = 0;
+
+    public BracketElement(int line, int pos) {
+        super(line, pos);
+    }
+
+    @Override
+    public int handleChar(char c) throws SyntaxError {
+        if (c == ')') {
+            return 2;
+        } else {
+            return 0;
+        }
+    }
+
+    @Override
+    public String getShortDescription() {
+        return getPositionAsString() + " (???";
+    }
+}
diff --git a/devTools/javaSanityCheck/src/element/CommentElement.java b/devTools/javaSanityCheck/src/element/CommentElement.java
index 0ae0908201c914db2284087e89079760d42ae245..e18e74194320713de6c34379f087929d1665e672 100644
--- a/devTools/javaSanityCheck/src/element/CommentElement.java
+++ b/devTools/javaSanityCheck/src/element/CommentElement.java
@@ -3,6 +3,9 @@ package org.arkerthan.sanityCheck.element;
 import org.arkerthan.sanityCheck.SyntaxError;
 import org.arkerthan.sanityCheck.UnknownStateException;
 
+/**
+ * @author Arkerthan
+ */
 public class CommentElement extends Element {
 	private int state = 0;
 	/*
@@ -43,6 +46,8 @@ public class CommentElement extends Element {
 			case 2:
 				if (c == '/') {
 					return 2;
+				} else if (c == '*') {
+					return 1;
 				}
 				state = 1;
 				break;
@@ -65,6 +70,6 @@ public class CommentElement extends Element {
 
 	@Override
 	public String getShortDescription() {
-		return null;
+		return getPositionAsString() + "comment";
 	}
 }
diff --git a/devTools/javaSanityCheck/src/element/Element.java b/devTools/javaSanityCheck/src/element/Element.java
index d0e1bf7cd1210b08f1f888103278cd66ad1a218d..205f700362b56e4616f65f9b92d8961e6118663d 100644
--- a/devTools/javaSanityCheck/src/element/Element.java
+++ b/devTools/javaSanityCheck/src/element/Element.java
@@ -2,6 +2,9 @@ package org.arkerthan.sanityCheck.element;
 
 import org.arkerthan.sanityCheck.SyntaxError;
 
+/**
+ * @author Arkerthan
+ */
 public abstract class Element {
 	protected KnownElement k;
 	protected int line, pos;
@@ -36,6 +39,15 @@ public abstract class Element {
 		return k;
 	}
 
+	/**
+	 * Returns the line and position of the Element in the file it was created in.
+	 *
+	 * @return position of Element in file as String
+	 */
+	public String getPositionAsString() {
+		return "[" + line + ":" + pos + "]";
+	}
+
 	/**
 	 * @return a short description usually based on state and position of the Element
 	 */
diff --git a/devTools/javaSanityCheck/src/element/KnownElement.java b/devTools/javaSanityCheck/src/element/KnownElement.java
index d09a5a7a5cc7279bda7cc03a0a674b1243217847..709fc3891776e4b6cb0c4fef77590d20fea1b9a6 100644
--- a/devTools/javaSanityCheck/src/element/KnownElement.java
+++ b/devTools/javaSanityCheck/src/element/KnownElement.java
@@ -2,6 +2,9 @@ package org.arkerthan.sanityCheck.element;
 
 import org.arkerthan.sanityCheck.SyntaxError;
 
+/**
+ * @author Arkerthan
+ */
 public abstract class KnownElement extends Element {
 
 	/**
diff --git a/devTools/javaSanityCheck/src/element/KnownHtmlElement.java b/devTools/javaSanityCheck/src/element/KnownHtmlElement.java
index 8ae21e1a402d3fd8c3a8a5010c03527aab2c9a3c..d7c25299ba4ac3a8e3bed8638597bea2bb0edc30 100644
--- a/devTools/javaSanityCheck/src/element/KnownHtmlElement.java
+++ b/devTools/javaSanityCheck/src/element/KnownHtmlElement.java
@@ -1,5 +1,8 @@
 package org.arkerthan.sanityCheck.element;
 
+/**
+ * @author Arkerthan
+ */
 public class KnownHtmlElement extends KnownElement {
 
 	private boolean opening;
@@ -20,7 +23,7 @@ public class KnownHtmlElement extends KnownElement {
 	@Override
 	public String getShortDescription() {
 		StringBuilder builder = new StringBuilder();
-		builder.append('[').append(line).append(":").append(pos).append("] <");
+		builder.append(getPositionAsString()).append(" <");
 		if (!opening) {
 			builder.append("/");
 		}
diff --git a/devTools/javaSanityCheck/src/element/KnownLogicElement.java b/devTools/javaSanityCheck/src/element/KnownLogicElement.java
index 994201c5a9ba40a4aea01252bb0ba6765a5841b7..5c8496a5c554a0967eb53e5c7e9cd4973f39f51c 100644
--- a/devTools/javaSanityCheck/src/element/KnownLogicElement.java
+++ b/devTools/javaSanityCheck/src/element/KnownLogicElement.java
@@ -6,6 +6,9 @@ import org.arkerthan.sanityCheck.UnknownStateException;
 import java.util.Arrays;
 import java.util.List;
 
+/**
+ * @author Arkerthan
+ */
 public class KnownLogicElement extends KnownElement {
 	private static final List<String> allowedTags = Arrays.asList("if", "elseif", "else");
 	private final int state;
@@ -86,7 +89,7 @@ public class KnownLogicElement extends KnownElement {
 	@Override
 	public String getShortDescription() {
 		StringBuilder builder = new StringBuilder();
-		builder.append("[").append(line).append(":").append(pos).append("] <<");
+		builder.append(getPositionAsString()).append(" <<");
 		if (last) {
 			builder.append('/');
 		}
diff --git a/devTools/javaSanityCheck/src/element/KnownTwineElement.java b/devTools/javaSanityCheck/src/element/KnownTwineElement.java
index 4bd78b2d585d014186d7ded56d804352e8e5d8db..9693fb840dfda0338d6d87ad2c602b6769126d3d 100644
--- a/devTools/javaSanityCheck/src/element/KnownTwineElement.java
+++ b/devTools/javaSanityCheck/src/element/KnownTwineElement.java
@@ -1,15 +1,17 @@
 package org.arkerthan.sanityCheck.element;
 
+/**
+ * @author Arkerthan
+ */
 public class KnownTwineElement extends KnownElement {
 
 	private boolean opening;
 	private String statement;
 
 	/**
-	 *
-	 * @param line at which it begins
-	 * @param pos at which it begins
-	 * @param opening if it opens a tag: <<tag>>  or closes it: <</tag>>
+	 * @param line	  at which it begins
+	 * @param pos	   at which it begins
+	 * @param opening   if it opens a tag: <<tag>>  or closes it: <</tag>>
 	 * @param statement statement inside the tag
 	 */
 	public KnownTwineElement(int line, int pos, boolean opening, String statement) {
@@ -21,7 +23,7 @@ public class KnownTwineElement extends KnownElement {
 	@Override
 	public String getShortDescription() {
 		StringBuilder builder = new StringBuilder();
-		builder.append("[").append(line).append(":").append(pos).append("] <<");
+		builder.append(getPositionAsString()).append(" <<");
 		if (!opening) {
 			builder.append("/");
 		}
diff --git a/java+gitGrep-sanityCheck.sh b/java+gitGrep-sanityCheck.sh
index 02e5e0853125872d38d548a37361eedd16fca35d..b46d4dd1c320dc803f254fd4816944efc01d3c9f 100755
--- a/java+gitGrep-sanityCheck.sh
+++ b/java+gitGrep-sanityCheck.sh
@@ -59,7 +59,7 @@ $GREP "\$slaves\[\$i\]\. " -- 'src/*' | myprint "MissingPropertyAfterSlaves"
 # Check using refreshmentType instead of refreshment
 $GREP "\$PC.refreshmentType[^ =]" -- 'src/*' | myprint "ShouldBeRefreshment"
 # Check, e.g., <<//if>>
-$GREP "<</[a-zA-Z]*[^a-zA-Z<>]\+[a-zA-Z]*>>" -- 'src/*' | myprint "DoubleSlash"
+#$GREP "<</[a-zA-Z]*[^a-zA-Z<>]\+[a-zA-Z]*>>" -- 'src/*' | myprint "DoubleSlash"
 # Check, e.g.  <<else $foo==4
 #$GREP "<<else >\?[^>]" -- 'src/*' | myprint "ShouldBeElseIf"
 # Check, e.g., =to
diff --git a/sanityCheck b/sanityCheck
index e8e842b19766a9b04452b30f317e5af78755a42f..50c71e27f7fc04ab30b17318084e1ddd0592a486 100755
--- a/sanityCheck
+++ b/sanityCheck
@@ -99,11 +99,13 @@ $GREP -e "<<option " --and --not -e "<<option  *\(-\?[0-9]\+\|[\'\"].*[\'\"]\|fa
 # check for missing ; before statement
 $GREP 'if $ ' -- 'src/*'  | myprint "missing ; before statement"
 $GREP 'elseif $ ' -- 'src/*'  | myprint "missing ; before statement"
+# Check for an unrecognized letter before >>
+$GREP "[^]a-zA-Z0-9 \")}'+-\*\`] *>>" -- 'src/*' | myprint "StrangeCharacterAtEndOfCommand"
 # Check for a . inside a <<>>
 $GREP "<<[a-zA-Z]\([^\"'>]\|[^\"'>]>[^\"'>]\)*[a-zA-Z][.][^a-zA-Z]" | myprint "StrangeCharacterAfterDot"
 # Check for @@. instead of .@@
 $GREP -E "@@(\.|,|;|:)\s" -- src/*.tw | myprint "WrongSelectorPunctuation"
-$GREP "@@[a-z]\+;" -- 'src/*' | myprint "@@MisingDot"
+$GREP "@@[a-z]\+;" -- 'src/*' | myprint "SelectorMissingDot"
 
 # Check that we do not have any variables that we use only once.   e.g.	 $onlyUsedOnce
 # Ignore  *Nationalities
diff --git a/slave variables documentation - Pregmod.txt b/slave variables documentation - Pregmod.txt
index 9c074ec631cb4337d0f280ad27944ca2d2368eb7..628e86e47718ba2d23bf1ee4426368875c1fedf4 100644
--- a/slave variables documentation - Pregmod.txt	
+++ b/slave variables documentation - Pregmod.txt	
@@ -2640,6 +2640,7 @@ vaginalAccessory:
 may accept strings, use at own risk
 "none"
 "bullet vibrator"
+"smart bullet vibrator"
 "dildo"
 "large dildo"
 "huge dildo"
@@ -3586,7 +3587,7 @@ geneMods:
 		0 - no
 		1 - yes
 	rapidCellGrowth:
-		Has the slave undergone the elasticity(plasticity) treatment?
+		Has the slave undergone the elasticity (plasticity) treatment?
 		0 - no
 		1 - yes
 
diff --git a/src/SecExp/SecExpBackwardCompatibility.tw b/src/SecExp/SecExpBackwardCompatibility.tw
index 1708368a8f1e4b921a17a88cd37abbc0a77688aa..8efeeb27226b8b128c52b13658afdbcbdf6d3741 100644
--- a/src/SecExp/SecExpBackwardCompatibility.tw
+++ b/src/SecExp/SecExpBackwardCompatibility.tw
@@ -433,20 +433,20 @@
 	defense: 0,
 	hp:0}>>
 <<else>>
-	<<if isInt($droneUpgrades)>>
+	<<if Number.isInteger($droneUpgrades)>>
 		<<unset $droneUpgrades>>
 		<<set $droneUpgrades = {
 		attack: 0,
 		defense: 0,
 		hp:0}>>
 	<</if>>
-	<<if ndef $droneUpgrades.attack || !isInt($droneUpgrades.attack)>>
+	<<if ndef $droneUpgrades.attack || !Number.isInteger($droneUpgrades.attack)>>
 		<<set $droneUpgrades.attack = 0>>
 	<</if>>
-	<<if ndef $droneUpgrades.defense || !isInt($droneUpgrades.defense)>>
+	<<if ndef $droneUpgrades.defense || !Number.isInteger($droneUpgrades.defense)>>
 		<<set $droneUpgrades.defense = 0>>
 	<</if>>
-	<<if ndef $droneUpgrades.hp || !isInt($droneUpgrades.hp)>>
+	<<if ndef $droneUpgrades.hp || !Number.isInteger($droneUpgrades.hp)>>
 		<<set $droneUpgrades.hp = 0>>
 	<</if>>
 <</if>>
@@ -463,7 +463,7 @@
 	hp:0,
 	morale: 0}>>
 <<else>>
-	<<if isInt($humanUpgrade)>>
+	<<if Number.isInteger($humanUpgrade)>>
 		<<unset $humanUpgrade>>
 		<<set $humanUpgrade = {
 		attack: 0,
@@ -471,16 +471,16 @@
 		hp:0,
 		morale: 0}>>
 	<</if>>
-	<<if ndef $humanUpgrade.attack || !isInt($humanUpgrade.attack)>>
+	<<if ndef $humanUpgrade.attack || !Number.isInteger($humanUpgrade.attack)>>
 		<<set $humanUpgrade.attack = 0>>
 	<</if>>
-	<<if ndef $humanUpgrade.defense || !isInt($humanUpgrade.defense)>>
+	<<if ndef $humanUpgrade.defense || !Number.isInteger($humanUpgrade.defense)>>
 		<<set $humanUpgrade.defense = 0>>
 	<</if>>
-	<<if ndef $humanUpgrade.hp || !isInt($humanUpgrade.hp)>>
+	<<if ndef $humanUpgrade.hp || !Number.isInteger($humanUpgrade.hp)>>
 		<<set $humanUpgrade.hp = 0>>
 	<</if>>
-	<<if ndef $humanUpgrade.morale || !isInt($humanUpgrade.morale)>>
+	<<if ndef $humanUpgrade.morale || !Number.isInteger($humanUpgrade.morale)>>
 		<<set $humanUpgrade.morale = 0>>
 	<</if>>
 <</if>>
diff --git a/src/SecExp/attackReport.tw b/src/SecExp/attackReport.tw
index c258dbdf444c4e78cf60c5e9c2e6adab4e13a053..d36aff21bcfe8eadd0e72a1d0041fa84b6650af9 100644
--- a/src/SecExp/attackReport.tw
+++ b/src/SecExp/attackReport.tw
@@ -750,7 +750,7 @@
 	<</if>>
 	<<run cashX(forceNeg($bribeCost), "war")>>
 <</if>>
-<<if !isInt($lowerClass)>>
+<<if !Number.isInteger($lowerClass)>>
 	<<if isNaN($lowerClass)>>
 		<br>@@.red;Error: lowerClass is NaN, please report this issue@@
 	<<elseif $lowerClass > 0>>
@@ -759,7 +759,7 @@
 		<<set $lowerClass = 0>>
 	<</if>>
 <</if>>
-<<if !isInt($NPCSlaves)>>
+<<if !Number.isInteger($NPCSlaves)>>
 	<<if isNaN($NPCSlaves)>>
 		<br>@@.red;Error: NPCSlaves is NaN, please report this issue@@
 	<<elseif $NPCSlaves > 0>>
diff --git a/src/SecExp/rebellionGenerator.tw b/src/SecExp/rebellionGenerator.tw
index a8b7d30003150fa013f80419b69d157f20eb573e..7f629bc71fb98e6696fe9277dd793e994097d404 100644
--- a/src/SecExp/rebellionGenerator.tw
+++ b/src/SecExp/rebellionGenerator.tw
@@ -196,7 +196,7 @@
 	<<elseif $citizenRebellionEventFires == 1>>
 		@@.red;citizen malcontent increased@@.
 	<</if>>
-<<elseif !isInt($tension)>>
+<<elseif !Number.isInteger($tension)>>
 	<br>Error: tension is outside accepted range.
 <</if>>
 
diff --git a/src/SecExp/unitsBattleReport.tw b/src/SecExp/unitsBattleReport.tw
index fce1092cc1b686f22419014aaa28e9be13209071..503111bf7546bdde879d02bebee1d0f7c35d9730 100644
--- a/src/SecExp/unitsBattleReport.tw
+++ b/src/SecExp/unitsBattleReport.tw
@@ -81,7 +81,7 @@
 	/* sanity check for losses */
 	<<set _count = 0>>
 	<<for _i = 0; _i < _lossesList.length; _i++>>
-		<<if !isInt(_lossesList[_i])>>
+		<<if !Number.isInteger(_lossesList[_i])>>
 			<<set _lossesList[_i] = 0>>
 		<</if>>
 		<<set _count += _lossesList[_i]>>
diff --git a/src/SecExp/unitsRebellionReport.tw b/src/SecExp/unitsRebellionReport.tw
index 235bbacc991fbb26961f821054ffb46cb036de58..7b6a1c20c85fc22263be5be3efe7074d0dd5106c 100644
--- a/src/SecExp/unitsRebellionReport.tw
+++ b/src/SecExp/unitsRebellionReport.tw
@@ -279,7 +279,7 @@
 	/* sanity check for losses */
 	<<set _count = 0>>
 	<<for _i = 0; _i < _lossesList.length; _i++>>
-		<<if !isInt(_lossesList[_i])>>
+		<<if !Number.isInteger(_lossesList[_i])>>
 			<<set _lossesList[_i] = 0>>
 		<</if>>
 		<<set _count += _lossesList[_i]>>
diff --git a/src/SecExp/widgets/battleWidgets.tw b/src/SecExp/widgets/battleWidgets.tw
index fbf36b41b7c4a108e98bdceab28245703f3049f7..183ca80de9af834dd8e2574bac6db1a6be6978cb 100644
--- a/src/SecExp/widgets/battleWidgets.tw
+++ b/src/SecExp/widgets/battleWidgets.tw
@@ -4,14 +4,14 @@
 	<<if $slaveRebellion != 1 || $citizenRebellion != 1>>
 		/* atk, def */
 		<<set _upgradesSum = $SF.Squad.Armoury + $SF.Squad.Drugs + ($SF.Squad.AA+$SF.Squad.TA < 1) + ($SF.Squad.AV+$SF.Squad.TV)>>
-		<<if !isInt(_upgradesSum)>>
+		<<if !Number.isInteger(_upgradesSum)>>
 			<<set _upgradesSum = random(10,15)>>
 		<</if>>
 		<<set $SFatk = Math.trunc(0.65 * _upgradesSum)>>
 		<<set $SFdef = Math.trunc(0.40 * _upgradesSum)>>
 		/* hp */
 		<<set $carriableSoldiers = 125 * ($SF.Squad.GunS + (($SF.Squad.AV + $SF.Squad.TV)/2))>>
-		<<if !isInt($carriableSoldiers)>>
+		<<if !Number.isInteger($carriableSoldiers)>>
 			<<set $carriableSoldiers = $SF.Squad.Troops / 10>>
 		<</if>>
 		<<if $SF.Squad.Troops > $carriableSoldiers>>
@@ -23,7 +23,7 @@
 	<<else>>
 		/* atk, def */
 		<<set _upgradesSum = $SF.Squad.Armoury + $SF.Squad.Drugs + ($SF.Squad.AA+$SF.Squad.TA < 1) + ($SF.Squad.AV+$SF.Squad.TV)>>
-		<<if !isInt(_upgradesSum)>>
+		<<if !Number.isInteger(_upgradesSum)>>
 			<<set _upgradesSum = random(10,15)>>
 		<</if>>
 		<<set $SFatk = Math.trunc(0.75 * _upgradesSum)>>
diff --git a/src/SecExp/widgets/miscSecExpWidgets.tw b/src/SecExp/widgets/miscSecExpWidgets.tw
index e704c8f183aeca1e8f57d2b7b25fec165cf00fea..5fd970e2375ccf76b80e681f5a6e1b409c48aca3 100644
--- a/src/SecExp/widgets/miscSecExpWidgets.tw
+++ b/src/SecExp/widgets/miscSecExpWidgets.tw
@@ -233,7 +233,7 @@
 		<br>Fixed security bots wrong max troop count.
 		<<set $secBots.maxTroops = 30>>
 	<</if>>
-	<<if !isInt($secBots.troops)>>
+	<<if !Number.isInteger($secBots.troops)>>
 		<br>Fixed security bots wrong max troop count.
 		<<set $secBots.troops = $secBots.maxTroops>>
 	<</if>>
@@ -263,7 +263,7 @@
 			<br>Fixed militia unit wrong max troop count.
 			<<set $militiaUnits[_i].maxTroops = 30>>
 		<</if>>
-		<<if !isInt($militiaUnits[_i].troops)>>
+		<<if !Number.isInteger($militiaUnits[_i].troops)>>
 			<<set $militiaUnits[_i].troops = $militiaUnits[_i].maxTroops>>
 			<br>Fixed militia unit wrong troop count.
 		<</if>>
@@ -294,7 +294,7 @@
 			<br>Fixed slave unit wrong max troop count.
 			<<set $slaveUnits[_i].maxTroops = 30>>
 		<</if>>
-		<<if !isInt($slaveUnits[_i].troops)>>
+		<<if !Number.isInteger($slaveUnits[_i].troops)>>
 			<<set $slaveUnits[_i].troops = $slaveUnits[_i].maxTroops>>
 			<br>Fixed slave unit wrong troop count.
 		<</if>>
@@ -325,7 +325,7 @@
 			<br>Fixed merc unit wrong max troop count.
 			<<set $mercUnits[_i].maxTroops = 30>>
 		<</if>>
-		<<if !isInt($mercUnits[_i].troops)>>
+		<<if !Number.isInteger($mercUnits[_i].troops)>>
 			<<set $mercUnits[_i].troops = $mercUnits[_i].maxTroops>>
 			<br>Fixed merc unit wrong troop count.
 		<</if>>
@@ -337,37 +337,37 @@
 <</widget>>
 
 <<widget "fixBrokenStats">>
-	<<if !isInt($totalKills)>>
+	<<if !Number.isInteger($totalKills)>>
 		<<set $totalKills = 0>>
 	<</if>>
-	<<if !isInt($mercTotalCasualties)>>
+	<<if !Number.isInteger($mercTotalCasualties)>>
 		<<set $mercTotalCasualties = 0>>
 	<</if>>
-	<<if !isInt($mercEmployedManpower)>>
+	<<if !Number.isInteger($mercEmployedManpower)>>
 		<<set $mercEmployedManpower = 0>>
 	<</if>>
-	<<if !isInt($mercTotalManpower)>>
+	<<if !Number.isInteger($mercTotalManpower)>>
 		<<set $mercTotalManpower = 0>>
 	<</if>>
-	<<if !isInt($slavesTotalCasualties)>>
+	<<if !Number.isInteger($slavesTotalCasualties)>>
 		<<set $slavesTotalCasualties = 0>>
 	<</if>>
-	<<if !isInt($slavesEmployedManpower)>>
+	<<if !Number.isInteger($slavesEmployedManpower)>>
 		<<set $slavesEmployedManpower = 0>>
 	<</if>>
-	<<if !isInt($militiaTotalCasualties)>>
+	<<if !Number.isInteger($militiaTotalCasualties)>>
 		<<set $militiaTotalCasualties = 0>>
 	<</if>>
-	<<if !isInt($militiaEmployedManpower)>>
+	<<if !Number.isInteger($militiaEmployedManpower)>>
 		<<set $militiaEmployedManpower = 0>>
 	<</if>>
-	<<if !isInt($militiaFreeManpower)>>
+	<<if !Number.isInteger($militiaFreeManpower)>>
 		<<set $militiaFreeManpower = 0>>
 	<</if>>
-	<<if !isInt($militiaTotalManpower)>>
+	<<if !Number.isInteger($militiaTotalManpower)>>
 		<<set $militiaTotalManpower = 0>>
 	<</if>>
-	<<if !isInt($battlesCount)>>
+	<<if !Number.isInteger($battlesCount)>>
 		<<set $battlesCount = 0>>
 	<</if>>
 <</widget>>
diff --git a/src/SpecialForce/SpecialForce.js b/src/SpecialForce/SpecialForce.js
index ab9e33d0f5c1ea26286c863741f2251cce3b7577..79f1f7341d450e40f7b577254e1006eb78190640 100644
--- a/src/SpecialForce/SpecialForce.js
+++ b/src/SpecialForce/SpecialForce.js
@@ -2,29 +2,44 @@
 /* eslint-disable no-undef */
 //V=SugarCube.State.variables, T=SugarCube.State.temporary;
 window.Main = function() {
- const V=State.variables;
- V.SF={Toggle:V.SF.Toggle,Active:-1,Depravity:0, Size:0, Upgrade:0, Gift:0, UC:{Assign:0, Lock:0, num:0}, ROE:"hold", Target:"recruit", Regs:"strict", Caps:"The Special Force", Lower:"the special force", Subsidy:1, BadOutcome:""};
- V.arcologies[0].SFRaid=1; V.arcologies[0].SFRaidTarget=-1;
+ const V = State.variables;
+ V.SF = {
+		Toggle:V.SF.Toggle,Active:-1,Depravity:0, Size:0, Upgrade:0, Gift:0,
+		UC:{Assign:0, Lock:0, num:0}, ROE:"hold", Target:"recruit", Regs:"strict",
+		Caps:"The Special Force", Lower:"the special force", Subsidy:1, BadOutcome:""
+	};
+ V.arcologies[0].SFRaid = 1; V.arcologies[0].SFRaidTarget = -1;
 };
 window.Squad = function() {
- const V=State.variables;
- V.SF.Squad={Troops:40, Armoury:0, Firebase:0, AV:0, TV:0, Drones:0, Drugs:0, PGT:0, AA:0, TA:0, SpacePlane:0, GunS:0, Satellite:{lv:0, InOrbit:0}, GiantRobot:0, MissileSilo:0, AircraftCarrier:0, Sub:0, HAT:0};
+ const V = State.variables;
+ V.SF.Squad = {
+		Troops:40, Armoury:0, Firebase:0, AV:0, TV:0, Drones:0, Drugs:0,
+		PGT:0, AA:0, TA:0, SpacePlane:0, GunS:0, Satellite:{lv:0, InOrbit:0},
+		GiantRobot:0, MissileSilo:0, AircraftCarrier:0, Sub:0, HAT:0
+	};
 };
 window.Colonel = function() {
- const V=State.variables;
- V.SF.Colonel={Core:"", Talk:0, Fun:0, Status:0};
+ const V = State.variables;
+ V.SF.Colonel = {Core:"", Talk:0, Fun:0, Status:0};
 };
 window.MercCon = function() {
- const V=State.variables;
- V.SF.MercCon={History:0, CanAttend:-2, Income:0, Revenue:0, Menials:0, TotalMenials:0, Mercs:0, TotalMercs:0};
+ const V = State.variables;
+ V.SF.MercCon = {
+		History:0, CanAttend:-2, Income:0, Revenue:0, Menials:0,
+		TotalMenials:0, Mercs:0, TotalMercs:0
+	};
 };
 window.Facility = function() {
- const V=State.variables;
- V.SF.Facility={Toggle:0, Active:0, LC:0, Workers:0, Max:5, Caps:"Special force support facility", Lower:"special force support facility", Decoration:"standard", Speed:0, Upgrade:0, IDs:[]};
+ const V = State.variables;
+ V.SF.Facility = {
+		Toggle:0, Active:0, LC:0, Workers:0, Max:5,
+		Caps:"Special force support facility", Lower:"special force support facility",
+		Decoration:"standard", Speed:0, Upgrade:0, IDs:[]
+	};
 };
 
 window.SFInit = function() {
- Main();Squad();Colonel();
+ Main(); Squad(); Colonel();
 };
 
 window.SFBC = function() {
@@ -34,7 +49,7 @@ window.SFBC = function() {
 		}
 	}
 
-	const V=State.variables;
+	const V = State.variables;
 	function InitClean() {
 		jsDel([V.SFMODToggle,V.securityForceActive,V.securityForceCreate,V.securityForceEventSeen]);
 	}
@@ -59,11 +74,16 @@ window.SFBC = function() {
 	}
 
 	if (V.SF === undefined) {
-		if (V.securityForceEventSeen < 1) { V.securityForceActive=-1; } else { V.securityForceActive=2; }
-		V.SF={Toggle:V.SFMODToggle, Active:V.securityForceActive}; InitClean();
-		if (V.securityForceName === undefined) V.securityForceName="the special force";
+		if (V.securityForceEventSeen < 1) {
+			V.securityForceActive = -1;
+		} else {
+			V.securityForceActive = 2;
+		}
+		V.SF = {Toggle:V.SFMODToggle, Active:V.securityForceActive}; InitClean();
+		if (V.securityForceName === undefined) V.securityForceName = "the special force";
 		if (V.SF.Active >= 1) {
-			Object.assign(V.SF, {
+			Object.assign(V.SF,
+			{
 				Depravity:V.securityForceDepravity,
 				Size:V.SFAO,
 				Upgrade:V.securityForceUpgradeToken,
@@ -74,13 +94,14 @@ window.SFBC = function() {
 				Regs:V.securityForceAccountability,
 				Caps:"The Special Force",
 				Lower:V.securityForceName,
-				Subsidy:V.SubsidyActive}); MainClean();
-			 SFNameCapsCheck();
+				Subsidy:V.SubsidyActive
+			});
+			MainClean(); SFNameCapsCheck();
 
-			if (V.ColonelCore === undefined) V.ColonelCore="";
+			if (V.ColonelCore === undefined) V.ColonelCore = "";
 			if (V.ColonelDiscussion === undefined) V.ColonelDiscussion = 0;
 			if (V.ColonelSexed === undefined) V.ColonelSexed = 0;
-			V.SF.Colonel={
+			V.SF.Colonel = {
 				Core:V.ColonelCore,
 				Talk:V.securityForceColonelToken,
 				Fun:V.securityForceColonelSexed,
@@ -90,7 +111,7 @@ window.SFBC = function() {
 			if (V.TotalTradeShowIncome === undefined) V.TotalTradeShowIncome = 0;
 			if (V.TradeShowHelots === undefined) V.TradeShowHelots = 0;
 			if (V.TotalTradeShowHelots === undefined) V.TotalTradeShowHelots = 0;
-			V.SF.MercCon={
+			V.SF.MercCon = {
 				History:V.OverallTradeShowAttendance,
 				CanAttend:V.CurrentTradeShowAttendance,
 				Income:V.TradeShowIncome,
@@ -110,7 +131,8 @@ window.SFBC = function() {
 			if (V.securityForceAircraftCarrier === undefined) V.securityForceAircraftCarrier = 0;
 			if (V.securityForceSubmarine === undefined) V.securityForceSubmarine = 0;
 			if (V.securityForceHeavyAmphibiousTransport === undefined) V.securityForceHeavyAmphibiousTransport = 0;
-			V.SF.Squad={
+			V.SF.Squad =
+			{
 				Troops:V.securityForcePersonnel,
 				Armoury:V.securityForceInfantryPower,
 				Firebase:V.securityForceArcologyUpgrades,
@@ -128,57 +150,61 @@ window.SFBC = function() {
 				MissileSilo:V.securityForceMissileSilo,
 				AircraftCarrier:V.securityForceAircraftCarrier,
 				Sub:V.securityForceSubmarine,
-				HAT:V.securityForceHeavyAmphibiousTransport}; UnitsClean();
+				HAT:V.securityForceHeavyAmphibiousTransport
+			};
+			UnitsClean();
 		} else {
 			SFInit();
 		}
 	} else {
 		if (V.SF.MercCon && V.SF.MercCon.View) delete V.SF.MercCon.View;
-		if (V.SFUC > 0) V.SF.UC.num=V.SFUC; delete V.SFUC;
+		if (V.SFUC > 0) V.SF.UC.num = V.SFUC; delete V.SFUC;
 		if (V.SF.Active === -1) SFInit();
 		if (V.SF.MWU) delete V.SF.MWU;
-		if (V.SpecOpsLock !== undefined) V.SF.SpecOpsLock=V.SpecOpsLock; delete V.SpecOpsLock;
+		if (V.SpecOpsLock !== undefined) V.SF.SpecOpsLock = V.SpecOpsLock; delete V.SpecOpsLock;
 		if (V.SF.UC === undefined) {
 			if (V.SF.SpecOps !== undefined && V.SF.SpecOpsLock !== undefined) {
-				V.SF.UC={Assign:V.SF.SpecOps, Lock:V.SF.SpecOpsLock};
+				V.SF.UC = {Assign:V.SF.SpecOps, Lock:V.SF.SpecOpsLock};
 				jsDel([V.SF.SpecOps,V.SF.SpecOpsLock]);
 			} else if (V.SF.UC === {}) {
-				V.SF.UC={Assign:0, Lock:0};
+				V.SF.UC = {Assign:0, Lock:0};
 			}
 		}
-		if (V.SF.U !== undefined) V.SF.Upgrade=V.SF.U; delete V.SF.U;
-		if (V.SF.WG !== undefined) V.SF.Gift=V.SF.WG; delete V.SF.WG;
+		if (V.SF.U !== undefined) V.SF.Upgrade = V.SF.U; delete V.SF.U;
+		if (V.SF.WG !== undefined) V.SF.Gift = V.SF.WG; delete V.SF.WG;
 
 		if (V.SF.MercCon === undefined) MercCon();
 		if (V.SF.MercCon.Helots !== undefined) {
-			V.SF.MercCon.Menials=V.SF.MercCon.Helots;
+			V.SF.MercCon.Menials = V.SF.MercCon.Helots;
 			delete V.SF.MercCon.Helots;
 		} else { V.SF.MercCon.Menials = 0; }
 		if (V.SF.MercCon.TotalHelots !== undefined) {
-			V.SF.MercCon.TotalMenials=V.SF.MercCon.TotalHelots;
+			V.SF.MercCon.TotalMenials = V.SF.MercCon.TotalHelots;
 			delete V.SF.MercCon.TotalHelots;
-		} else { V.SF.MercCon.TotalMenials = 0; }
+		} else {
+			V.SF.MercCon.TotalMenials = 0;
+		}
 
 		if (V.SF.Bonus !== undefined) delete V.SF.Bonus;
 		if (V.SF.Depravity < 0) V.SF.Depravity = 0;
-		if (V.SF.Size === undefined) V.SF.Size=V.SF.Units; delete V.SF.Units;
+		if (V.SF.Size === undefined) V.SF.Size = V.SF.Units; delete V.SF.Units;
 		if (V.SFUnit !== undefined) {
 			if (V.SFUnit.AT !== undefined) V.SFUnitTA = 0;
-			V.SF.Squad.Satellite=V.SF.Squad.Sat;
+			V.SF.Squad.Satellite = V.SF.Squad.Sat;
 			jsDel([V.SF.Squad.Sat,V.SatLaunched,V.SFUnit.AT]);
-			V.SF.Squad.Satellite=V.SF.Squad.Sat; delete V.SF.Squad.Sat;
-			if (V.SFTradeShow !== undefined) V.SF.MercCon=V.SFTradeShow; delete V.SFTradeShow;
-			if (V.SFColonel !== undefined) V.SF.Colonel=V.SFColonel; delete V.SFColonel;
-			if (V.SF.BadOutcome === undefined) V.SF.BadOutcome="";
+			V.SF.Squad.Satellite = V.SF.Squad.Sat; delete V.SF.Squad.Sat;
+			if (V.SFTradeShow !== undefined) V.SF.MercCon = V.SFTradeShow; delete V.SFTradeShow;
+			if (V.SFColonel !== undefined) V.SF.Colonel = V.SFColonel; delete V.SFColonel;
+			if (V.SF.BadOutcome === undefined) V.SF.BadOutcome = "";
 			if (V.SF.Squad.Satellite !== undefined && V.SatLaunched === undefined) {
-				V.SF.Squad.Sat={lv:0, InOrbit:0};
-				V.SF.Squad.Satellite=V.SF.Squad.Sat;
+				V.SF.Squad.Sat = {lv:0, InOrbit:0};
+				V.SF.Squad.Satellite = V.SF.Squad.Sat;
 				jsDel([V.SF.Squad.Sat,V.SatLaunched,V.SFUnit]);
 			}
 		}
 		if (V.SF.Squad !== undefined && V.SF.Squad.Satellite.lv === undefined) {
-			V.SF.Squad.Sat={lv:V.SF.Squad.Satellite, InOrbit:0};
-			V.SF.Squad.Satellite=V.SF.Squad.Sat; delete V.SF.Squad.Sat;
+			V.SF.Squad.Sat = {lv:V.SF.Squad.Satellite, InOrbit:0};
+			V.SF.Squad.Satellite = V.SF.Squad.Sat; delete V.SF.Squad.Sat;
 		}
 	}
  if (V.securityForceName !== undefined) InitClean(); MainClean(); ColonelClean(); TradeShowClean(); UnitsClean();
@@ -186,30 +212,40 @@ window.SFBC = function() {
 };
 
 window.SFReport = function() {
-	"use strict"; const V=State.variables,T=State.temporary,S=V.SF.Squad;
-	let target=50000,baseLine=5000,profit = 0,upkeep = 0,income = 0;
-	let Multiplier={action:1,troop:1,unit:1,depravity:1},SFD=V.SF.Depravity;
-	let FNG=10,unitCap=2500,Trade = 0.025,deaths = 0,r=``; Count();
-	let cost={a:0.01,b:2.5};let NO=1+(V.SF.Size/5);let N1=1+(V.SF.Size/5);
-	V.SF.UC.num = 0; if (profit < 1) cost.a=10; cost.b = 0.1;NO=1;N1 = 0.1;
-
-	if (S.Troops > unitCap) S.Troops=unitCap;
-	if (S.Troops < 100) { S.Troops += Math.ceil(jsRandom(2,5));
+	"use strict"; const V = State.variables, T = State.temporary, S = V.SF.Squad;
+	let target = 50000, baseLine = 5000, profit = 0, upkeep = 0, income = 0;
+	let Multiplier = {action:1, troop:1, unit:1, depravity:1};
+	let FNG = 10, unitCap = 2500, Trade = 0.025;
+	let cost = {a:0.01,b:2.5}, NO = 1+(V.SF.Size/5), N1 = 1+(V.SF.Size/5);
+
+	V.SF.UC.num = 0; Count(); let r = ``, deaths = 0, SFD = V.SF.Depravity;
+	if (profit < 1) cost.a = 10; cost.b = 0.1; NO = 1; N1 = 0.1;
+
+	if (S.Troops > unitCap) S.Troops = unitCap;
+	if (S.Troops < 100) {
+		S.Troops += Math.ceil(jsRandom(2,5));
 	} else {
 		if (V.SF.Target === "recruit") {
 			S.Troops -= Math.ceil(jsRandom(1*S.Troops/1000,0));
 		} else if (V.SF.Target === "raiding") {
 			S.Troops -= Math.ceil(jsRandom(1.15*S.Troops/1000,-1.20*S.Troops/1000));
-		} else { S.Troops -= Math.ceil(jsRandom(1.10*S.Troops/1000,-1.15*S.Troops/1000)); }
+		} else {
+			S.Troops -= Math.ceil(jsRandom(1.10*S.Troops/1000,-1.15*S.Troops/1000));
+		}
 	}
 	if (V.SF.UC.Assign > 0) {
-		if (V.SF.UC.Assign < 2) { V.SF.UC.num=Math.ceil(S.Troops*0.01);
-		} else { V.SF.UC.num=Math.ceil(S.Troops*0.05); }
-	} S.Troops -= V.SF.UC.num;
-	if (S.Troops > 200) { Trade += 0.05*(Math.ceil(S.Troops/100));
+		if (V.SF.UC.Assign < 2) {
+			V.SF.UC.num = Math.ceil(S.Troops*0.01);
+		} else {
+			V.SF.UC.num = Math.ceil(S.Troops*0.05);
+		}
+	}
+	S.Troops -= V.SF.UC.num;
+	if (S.Troops > 200) {
+		Trade += 0.05*(Math.ceil(S.Troops/100));
 		Multiplier.troop += S.Troops/200; upkeep += (S.Troops*25)/cost.a;
 		if (V.secExp > 0) {
-			V.authority += 25*(Math.ceil(S.Troops/200)); V.authority=Math.clamp(V.authority, 0, 20000);
+			V.authority += 25*(Math.ceil(S.Troops/200)); V.authority = Math.clamp(V.authority, 0, 20000);
 		}
 	}
 
@@ -279,34 +315,59 @@ window.SFReport = function() {
 		case "jaded": Trade -= 0.05; SFD += 0.05; break;
 		case "shell shocked": Trade += 0.05; SFD -= 0.05; Multiplier.unit -= 0.5; break;
 	}
-	if (V.SF.Target === "raiding") { SFD += 0.05; Multiplier.action += 0.5;
-		} else if (V.SF.Target === "secure") { SFD -= 0.05; Multiplier.action += 0.2;
-		} else { SFD -= 0.1; Multiplier.action -= 0.5; }
-	if (V.SF.ROE === "free") { Multiplier.action *= 0.8; SFD += 0.05; Trade += Trade*0.95;
-	} else if (V.SF.ROE == "hold") { Multiplier.action *= 1.1; SFD -= 0.05; Trade += Trade*1.05; }
-	if (V.SF.Regs === "none") { Multiplier.action *= 0.8; SFD += 0.05; Trade += Trade*0.95;
-		} else if (V.SF.Regs === "strict") { Multiplier.action *= 1.1; SFD -= 0.05; Trade += Trade*1.05;
-	Multiplier.depravity=1+SFD; }
+
+	if (V.SF.Target === "raiding") {
+		SFD += 0.05; Multiplier.action += 0.5;
+	} else if (V.SF.Target === "secure") {
+		SFD -= 0.05; Multiplier.action += 0.2;
+	} else {
+		SFD -= 0.1; Multiplier.action -= 0.5;
+	}
+	if (V.SF.ROE === "free") {
+		Multiplier.action *= 0.8; SFD += 0.05; Trade += Trade*0.95;
+	} else if (V.SF.ROE === "hold") {
+		Multiplier.action *= 1.1; SFD -= 0.05; Trade += Trade*1.05;
+	}
+	if (V.SF.Regs === "none") {
+			Multiplier.action *= 0.8; SFD += 0.05; Trade += Trade*0.95;
+		} else if (V.SF.Regs === "strict") {
+			Multiplier.action *= 1.1; SFD -= 0.05; Trade += Trade*1.05;
+			Multiplier.depravity = 1+SFD;
+		}
 	if (SFD > -2) Trade *= 1+SFD/2;
 
-	if (V.SF.Target === "recruit") { FNG += Math.ceil(FNG*0.95);
-		} else { FNG += Math.ceil(FNG*0.25); }
-	if (V.SF.Target === "secure") { repX((Math.ceil(V.rep*((Trade/100)*0.95))), "specialForces");
-		V.arcologies[0].prosperity=Math.ceil((V.arcologies[0].prosperity+(Trade/10)*0.95));
-	} else { repX((Math.ceil(V.rep*(Trade/100)*0.25)), "specialForces");
-		V.arcologies[0].prosperity=Math.ceil(V.arcologies[0].prosperity+(Trade/10)*0.25);}
-	if (V.secExp > 0) V.authority += V.SF.Size*10; V.authority=Math.clamp(V.authority, 0, 20000);
+	if (V.SF.Target === "recruit") {
+		FNG += Math.ceil(FNG*0.95);
+	} else {
+		FNG += Math.ceil(FNG*0.25);
+	}
+
+	if (V.SF.Target === "secure") {
+		repX((Math.ceil(V.rep*((Trade/100)*0.95))), "specialForces");
+		V.arcologies[0].prosperity = Math.ceil((V.arcologies[0].prosperity+(Trade/10)*0.95));
+	} else {
+		repX((Math.ceil(V.rep*(Trade/100)*0.25)), "specialForces");
+		V.arcologies[0].prosperity = Math.ceil(V.arcologies[0].prosperity+(Trade/10)*0.25);
+	}
+	if (V.secExp > 0) V.authority += V.SF.Size*10; V.authority = Math.clamp(V.authority, 0, 20000);
+
+	income += Math.ceil( ( (baseLine* (0.09+Multiplier.troop/NO).toFixed(2) * (0.09+Multiplier.unit/NO).toFixed(2) * (0.09+Multiplier.action/NO).toFixed(2) * (0.09+Multiplier.depravity/NO).toFixed(2) ) - (upkeep*N1).toFixed(2) )/((V.SF.Size/2+S.Troops/2)*5) );
+	S.Troops += Math.round(FNG/2);
+	if (V.debugMode > 0) r += `<br>income:${num(income)}, troop:${num((0.09+Multiplier.troop/NO).toFixed(2))}, unit:${num((0.09+Multiplier.unit/NO).toFixed(2))}, action:${num((0.09+Multiplier.action/NO).toFixed(2))}, depravity:${num((0.09+Multiplier.depravity/NO).toFixed(2))}, upkeep:${num((upkeep*N1).toFixed(2))}`;
 
-	income += Math.ceil( ( (baseLine* (0.09+Multiplier.troop/NO).toFixed(2) * (0.09+Multiplier.unit/NO).toFixed(2) * (0.09+Multiplier.action/NO).toFixed(2) * (0.09+Multiplier.depravity/NO).toFixed(2) ) - (upkeep*N1).toFixed(2) )/((V.SF.Size/2+S.Troops/2)*5) ); S.Troops += Math.round(FNG/2);
-	if (V.debugMode > 0) r += `<br>income:${commaNum(income)}, troop:${commaNum((0.09+Multiplier.troop/NO).toFixed(2))}, unit:${commaNum((0.09+Multiplier.unit/NO).toFixed(2))}, action:${commaNum((0.09+Multiplier.action/NO).toFixed(2))}, depravity:${commaNum((0.09+Multiplier.depravity/NO).toFixed(2))}, upkeep:${commaNum((upkeep*N1).toFixed(2))}`;
 	if (V.economy < 100) income *= 83; //Remove line if hard mode ever gets fixed.
-	if (income >= target) profit=1; delete V.SF.Subsidy; cashX(income, "specialForces");
-	if (S.Troops > unitCap) S.Troops=unitCap;
-	if (V.arcologies[0].prosperity > V.ProsperityCap) V.arcologies[0].prosperity=V.ProsperityCap;
+	if (income >= target) profit = 1; delete V.SF.Subsidy; cashX(income, "specialForces");
+	if (S.Troops > unitCap) S.Troops = unitCap;
+	if (V.arcologies[0].prosperity > V.ProsperityCap) V.arcologies[0].prosperity = V.ProsperityCap;
 
-	if (S.Drugs >= 8 || S.Drugs >= 10) { let survivalChance=50;
-		if (S.Drugs >= 8) {survivalChance -= 5;} else if (S.Drugs >= 10) {survivalChance += 5;}
-		if (jsRandom(0,100) > survivalChance) deaths=jsRandom(0,((S.Drugs*2)+4));
+	if (S.Drugs >= 8 || S.Drugs >= 10) {
+		let survivalChance = 50;
+		if (S.Drugs >= 8) {
+			survivalChance -= 5;
+		} else if (S.Drugs >= 10) {
+			survivalChance += 5;
+		}
+		if (jsRandom(0,100) > survivalChance) deaths = jsRandom(0,((S.Drugs*2)+4));
 		if (deaths > 0) S.Troops -= deaths;
 	}
 	if (V.SF.UC.Assign === 1 && V.SF.UC.Lock < 1) V.SF.UC.Assign = 0;
@@ -314,7 +375,8 @@ window.SFReport = function() {
 	V.SF.Colonel.Talk = 0; V.SF.Colonel.Fun = 0;
 
 	r += `<br>__Week ${V.week} operational report for ${V.SF.Lower}__:`;
-	r += `<br>${V.SF.Caps} focused their ${commaNum(S.Troops)} troops on `;
+	r += `<br>${V.SF.Caps} focused their ${num(S.Troops)} troops on `;
+
 	if (V.SF.Target === "recruit") {
 		r += `recruiting and training more personnel. Smaller parties ventured out to protect the arcology's trade routes and strike targets of opportunity.`;
 	} else if (V.SF.Target === "secure") {
@@ -322,15 +384,18 @@ window.SFReport = function() {
 	} else {
 		r += `locating and striking targets of opportunity, capturing both material loot and new slaves. Smaller parties secured the most important of the arcology's trade routes and processed new recruits.`;
 	}
+
 	if (V.SF.UC.Assign > 0) {
 		r += `<br>A ${V.SF.UC.Assign < 2 ? 'small':'large'} portion of the force was assigned as ${V.SF.UC.Assign < 2 ? 'part':'full'} time undercover officers.`;
 	}
 	if (deaths > 0) {
-	 r += ` <span class='red'>${deaths} soldiers fatally overdosed on the drug cocktail</span>`;
+		r += ` <span class='red'>${deaths} soldiers fatally overdosed on the drug cocktail</span>`;
 		if (V.SF.MercCon.CanAttend === -1) r += `, The Colonel's much heavier than average drug use saves her from this side effect.`;
 	}
+
 	r += `<br>These activities have, overall, <span class='green'>improved your arcology's prosperity</span>.`;
-	r+= ` The goods procured by ${V.SF.Lower} after accounting for the spoils retained by individual soldiers were `;
+	r += ` The goods procured by ${V.SF.Lower} after accounting for the spoils retained by individual soldiers were `;
+
 	if (profit > 0) {
 		r += `<span class='green'>more than sufficient to cover expenses</span>. Excess material and human assets totaling <span class='yellowgreen'>${cashFormat(income)}</span> (after liquidation) were transferred to your accounts.`;
 		if (V.economy < 100) r += ` The rapidly degrading global economy has one upside,<span class='green'> ${V.SF.Caps} was able to more easily use more 'persuasive' techniques thus leading to an increase in profit</span>.`;
@@ -338,68 +403,92 @@ window.SFReport = function() {
 		r += `<span class='red'>barely enough to cover expenses.</span> More growth will be needed to ensure profitability, <span class='yellow'>hopefully purchasing more upgrades will help</span>.`;
 		r += ` Per the estimates that ${SFC()} provides, an additional <span class='yellowgreen'>${cashFormat(target-income)}</span> is required for sufficient cover.`;
 	}
+
 	r += ` ${V.SF.Caps} managed to recruit ${Math.round(FNG/2)} new soldiers this week, and your reputation has <span class='green'>increased through the improvement of trade security</span>.`;
 	r += `<br>//Your instructions to ${SFC()}://`;
-	r += `<br>&nbsp;Deployment focus: `;
-	 r += `<span id="focus"> <<if $SF.Target == "recruit">>''Recruiting and Training''<<elseif $SF.Target == "secure">>''Securing Trade Routes''<<else>>''Raiding and Slaving''<</if>></span>.&nbsp;&nbsp;`;
+
+	r += `<br>&nbsp;Deployment focus: `; //The below lines are indented to increase readability.
+		r += `<span id="focus"> <<if $SF.Target == "recruit">>''Recruiting and Training''<<elseif $SF.Target == "secure">>''Securing Trade Routes''<<else>>''Raiding and Slaving''<</if>></span>.&nbsp;&nbsp;`;
 		r += `<<link "Recruit and Train">> <<set $SF.Target="recruit">> <<replace "#focus">>''Recruiting and Training''<</replace>> <</link>> | <<link "Secure Trade Routes">> <<set $SF.Target="secure">> <<replace "#focus">>''Securing Trade Routes''<</replace>> <</link>> | <<link "Raiding and Slaving">> <<set $SF.Target="raiding">> <<replace "#focus">>''Raiding and Slaving''<</replace>> <</link>>`;
-	r += `<br>&nbsp;Rules of Engagement: `;
+
+	r += `<br>&nbsp;Rules of Engagement: `; //The below lines are indented to increase readability.
 		r += `<span id="roe"> <<if $SF.ROE === "hold">>''Hold Fire''<<elseif $SF.ROE === "limited">>''Limited Fire''<<else>>''Free Fire''<</if>></span>.&nbsp;&nbsp;`;
 		r += `<<link "Hold Fire">> <<set $SF.ROE="hold">> <<replace "#roe">>''Hold Fire''<</replace>> <</link>> | <<link "Limited Fire">> <<set $SF.ROE="limited">> <<replace "#roe">>''Limited Fire''<</replace>> <</link>> | <<link "Free Fire">> <<set $SF.ROE="free">> <<replace "#roe">>''Free Fire''<</replace>> <</link>>`;
-	r += `<br>&nbsp;Accountability: `;
+
+	r += `<br>&nbsp;Accountability: `; //The below lines are indented to increase readability.
 		r += `<span id="accountability"> <<if $SF.Regs === "strict">>''Strict Accountability''<<elseif $SF.Regs === "some">>''Some Accountability''<<else>>''No Accountability''<</if>></span>.&nbsp;&nbsp;`;
 		r += `<<link "Strict Accountability">> <<set $SF.Regs="strict">> <<replace "#accountability">>''Strict Accountability''<</replace>> <</link>> | <<link "Some Accountability">> <<set $SF.Regs="some">> <<replace "#accountability">>''Some Accountability''<</replace>> <</link>> | <<link "No Accountability">> <<set $SF.Regs="none">> <<replace "#accountability">>''No Accountability''<</replace>> <</link>>`;
+
 	if (V.SF.MercCon.CanAttend === 1) {
 		V.SF.MercCon.Income = 0; V.SF.MercCon.Menials = 0;
-		let tradeShowAttendes=200, menialGiftsPerAttendee=5, NewMercs = 0;
-		let menialGifts=Math.ceil(jsRandom(1,((tradeShowAttendes*menialGiftsPerAttendee)/10)));
-		let TSProfit=Math.ceil(500000*(1+(V.SF.Size/1000))*(1+(V.arcologies[0].prosperity/1000))*T.Env);
-		V.menials += menialGifts; V.SF.MercCon.History += 1;
+		let tradeShowAttendes = 200, menialGiftsPerAttendee = 5, NewMercs = 0;
+		let menialGifts = Math.ceil(jsRandom(1,((tradeShowAttendes*menialGiftsPerAttendee)/10)));
+		let TSProfit = Math.ceil(500000*(1+(V.SF.Size/1000))*(1+(V.arcologies[0].prosperity/1000))*T.Env);
+
 		V.SF.MercCon.Menials += menialGifts; V.SF.MercCon.TotalMenials += menialGifts;
+		V.menials += menialGifts; V.SF.MercCon.History += 1;
 		V.SF.MercCon.Income += TSProfit; V.SF.MercCon.Revenue += TSProfit;
 		cashX(TSProfit, "specialForces");
-		if (V.secExp > 0 && V.mercenaries > 0) { V.SF.MercCon.Mercs = 0;
-			NewMercs=jsRandom(1,(tradeShowAttendes/10));
+
+		if (V.secExp > 0 && V.mercenaries > 0) {
+			V.SF.MercCon.Mercs = 0;
+			NewMercs = jsRandom(1,(tradeShowAttendes/10));
 			V.mercFreeManpower += NewMercs; V.SF.MercCon.TotalMercs += NewMercs;
 			V.SF.MercCon.Mercs += NewMercs;
+			r += `<br>''TradeShow'': During a break, The Colonel managed to sell some generic schematics to the ${tradeShowAttendes} attendees, some of whom decided to also give a few menial slaves as a bonus.<br>`;
 		}
-		r += `<br>''TradeShow'': During a break, The Colonel managed to sell some generic schematics to the ${tradeShowAttendes} attendees, some of whom decided to also give a few menial slaves as a bonus.<br>`;
 	}
 	return r;
 };
 
 window.Count = function() {
-	const V=State.variables, T=State.temporary, C=Math.clamp, S=V.SF.Squad, E=V.economy;
-	T.FU=10; S.Firebase=C(S.Firebase, 0, T.FU);
-	T.AU=10; S.Armoury=C(S.Armoury, 0, T.AU);
-	T.DrugsU=10; S.Drugs=C(S.Drugs, 0, T.DrugsU);
-	T.DU=10; S.Drones=C(S.Drones, 0, T.DU);
-	T.AVU=10; S.AV=C(S.AV, 0, T.AVU);
-	T.TVU=10; S.TV=C(S.TV, 0, T.TVU);
-	T.AAU=10; S.AA=C(S.AA, 0, T.AAU);
-	T.TAU=10; S.TA=C(S.TA, 0, T.TAU);
-	if (V.PC.warfare >= 75) {T.PGTU=10; T.SPU=10; T.GunSU=10; T.SatU=10; T.GRU=10; T.MSU=10; T.ACU=10; T.SubU=10; T.HATU=10;}
-	else if (V.PC.warfare >= 50) {T.PGTU=9; T.SPU=9; T.GunSU=9; T.SatU=9; T.GRU=9; T.MSU=9; T.ACU=9; T.SubU=9; T.HATU=9;}
-	else {T.PGTU=8; T.SPU=8; T.GunSU=8; T.SatU=8; T.GRU=8; T.MSU=8; T.ACU=8; T.SubU=8; T.HATU=8;}
-	S.PGT=C(S.PGT, 0, T.PGTU);
-	S.SpacePlane=C(S.SpacePlane, 0, T.SPU); S.GunS=C(S.GunS, 0, T.GunSU);
-	S.Satellite.lv=C(S.Satellite.lv, 0, T.SatU); S.GiantRobot=C(S.GiantRobot, 0, T.GRU); S.MissileSilo=C(S.MissileSilo, 0, T.MSU);
-	S.AircraftCarrier=C(S.AircraftCarrier, 0, T.ACU); S.Sub=C(S.Sub, 0, T.SubU); S.HAT=C(S.HAT, 0, T.HATU);
-	T.GU=T.AVU+T.TVU+T.PGTU; T.G=S.AV+S.TV+S.PGT;
-	T.H=S.AA+S.TA+S.SpacePlane+S.GunS; T.HU=T.AAU+T.TAU+T.SPU+T.GunSU;
-	T.LBU=T.SatU+T.MSU; T.LB=S.Satellite.lv+S.MissileSilo;
-	T.Base=S.Firebase+S.Armoury+S.Drugs+S.Drones+T.H;
-	T.max=T.FU+T.AU+T.DrugsU+T.DU+T.HU;
-	//if (V.SF.Facility.Toggle > 0) T.Base += 1; T.max += 1;
-
-	if (V.terrain !== "oceanic" || V.terrain === "marine") { T.LBU += T.GRU; T.LB += S.GiantRobot; T.Base += T.G; T.max += T.GU;
-	T.max += T.LBU; T.Base += T.LB;
+	const V = State.variables, T = State.temporary, C = Math.clamp, S = V.SF.Squad, E = V.economy;
+	T.FU = 10; S.Firebase = C(S.Firebase, 0, T.FU);
+	T.AU = 10; S.Armoury = C(S.Armoury, 0, T.AU);
+	T.DrugsU = 10; S.Drugs = C(S.Drugs, 0, T.DrugsU);
+	T.DU = 10; S.Drones = C(S.Drones, 0, T.DU);
+	T.AVU = 10; S.AV = C(S.AV, 0, T.AVU);
+	T.TVU = 10; S.TV = C(S.TV, 0, T.TVU);
+	T.AAU = 10; S.AA = C(S.AA, 0, T.AAU);
+	T.TAU = 10; S.TA = C(S.TA, 0, T.TAU);
+
+	if (V.PC.warfare >=  75) {
+		T.PGTU = 10; T.SPU = 10; T.GunSU = 10; T.SatU = 10; T.GRU = 10; T.MSU = 10; T.ACU = 10; T.SubU = 10; T.HATU = 10;
+	} else if (V.PC.warfare >=  50) {
+		T.PGTU = 9; T.SPU = 9; T.GunSU = 9; T.SatU = 9; T.GRU = 9; T.MSU = 9; T.ACU = 9; T.SubU = 9; T.HATU = 9;}
+	else {
+		T.PGTU = 8; T.SPU = 8; T.GunSU = 8; T.SatU = 8; T.GRU = 8; T.MSU = 8; T.ACU = 8; T.SubU = 8; T.HATU = 8;
+	}
+
+	S.PGT = C(S.PGT, 0, T.PGTU);
+	S.SpacePlane = C(S.SpacePlane, 0, T.SPU); S.GunS = C(S.GunS, 0, T.GunSU);
+	S.Satellite.lv = C(S.Satellite.lv, 0, T.SatU); S.GiantRobot = C(S.GiantRobot, 0, T.GRU); S.MissileSilo = C(S.MissileSilo, 0, T.MSU);
+	S.AircraftCarrier = C(S.AircraftCarrier, 0, T.ACU); S.Sub = C(S.Sub, 0, T.SubU); S.HAT = C(S.HAT, 0, T.HATU);
+	T.GU = T.AVU+T.TVU+T.PGTU; T.G = S.AV+S.TV+S.PGT;
+	T.H = S.AA+S.TA+S.SpacePlane+S.GunS; T.HU = T.AAU+T.TAU+T.SPU+T.GunSU;
+	T.LBU = T.SatU+T.MSU; T.LB = S.Satellite.lv+S.MissileSilo;
+	T.Base = S.Firebase+S.Armoury+S.Drugs+S.Drones+T.H;
+	T.max = T.FU+T.AU+T.DrugsU+T.DU+T.HU;
+	//if (V.SF.Facility.Toggle > 0) T.Base + =  1; T.max + =  1;
+
+	if (V.terrain !== "oceanic" || V.terrain === "marine") {
+		T.LBU += T.GRU; T.LB += S.GiantRobot; T.Base += T.G; T.max += T.GU;
+		T.max += T.LBU; T.Base += T.LB;
+	} else {
+		T.NY = S.AircraftCarrier + S.Sub + S.HAT; T.Base += T.NY;
+		T.NYU = T.ACU + T.SubU + T.HATU; T.max += T.NYU;
+	}
+	V.SF.Size = T.Base; V.SF.Size = C(V.SF.Size, 1, T.max); T.T1 = 0;
+
+	if (E > 100) {
+		T.Env = 4;
+	} else if (E > 67) {
+		T.Env = 3;
 	} else {
-		T.NY=S.AircraftCarrier + S.Sub + S.HAT; T.Base += T.NY;
-		T.NYU=T.ACU + T.SubU + T.HATU; T.max += T.NYU;
-	} V.SF.Size=T.Base; V.SF.Size=C(V.SF.Size, 1, T.max); T.T1 = 0;
-	if (E > 100) {T.Env=4;} else if (E > 67) {T.Env=3;} else {T.Env=2;}
-	if (V.SF.Size >= 30) T.T1=1; T.SFSubsidy=5000*(1+((V.SF.Squad.Troops/100)+(V.SF.Size/100)));
+		T.Env = 2;
+	}
+
+	if (V.SF.Size >= 30) T.T1 = 1; T.SFSubsidy = 5000*(1+((V.SF.Squad.Troops/100)+(V.SF.Size/100)));
 	SFNameCapsCheck();
 	if (V.SF.IntroProgress > -1) delete V.SF.IntroProgress;
 	if (V.SF.MercCon === undefined) MercCon();
@@ -408,13 +497,13 @@ window.Count = function() {
 };
 
 window.SFNameCapsCheck = function() {
- const V=State.variables;
- if (V.SF.Lower !== "the special force") V.SF.Caps=V.SF.Lower.replace("the ", "The ");
+ const V = State.variables;
+ if (V.SF.Lower !== "the special force") V.SF.Caps = V.SF.Lower.replace("the ", "The ");
 };
 
 window.SFUpgradeCost = function(cost,unit) {
-	"use strict"; const V=State.variables,T=State.temporary,S=V.SF.Squad; let value = 0;
-	value=cost*T.Env*(1.15+(V.SF.Size/10))*(1.15+(unit/100));
+	"use strict"; const V=State.variables,T = State.temporary,S=V.SF.Squad; let value = 0;
+	value = cost*T.Env*(1.15+(V.SF.Size/10))*(1.15+(unit/100));
 	if ([S.Sub,S.AircraftCarrier,S.MissileSilo,S.GiantRobot,S.Satellite.lv,S.GunS,S.SpacePlane,S.Drones].includes(unit)) value *= V.HackingSkillMultiplier;
 	return Math.ceil(value);
 };
@@ -426,82 +515,93 @@ window.progress = function(x,max) {
 		if (State.variables.SF.Size < 30) {
 			z = 5 - x;
 			for (i = 0;i<x;i++) out += `█⏐`;
-			for (i = 0;i<z;i++) out += `<span style=\"opacity: 0;\">█</span>⏐`;
+			for (i = 0;i<z;i++) out += `<span style='opacity: 0;'>█</span>⏐`;
 			for (i = 0;i<5;i++) out += `░⏐`;}
 		else {
 			z = 10 - x;
 			for (i = 0;i<x;i++) out += `█⏐`;
-			for (i = 0;i<z;i++) out += `<span style=\"opacity: 0;\">█</span>⏐`;}}
+			for (i = 0;i<z;i++) out += `<span style='opacity: 0;'>█</span>⏐`;}}
 	else {
 		Math.clamp(x,0,max);
-		x=Math.floor(10*x/max);
-		z=10 - x;
+		x = Math.floor(10*x/max);
+		z = 10 - x;
 		for (i = 0;i<x;i++) out += `█⏐`;
-		for (i = 0;i<z;i++) out += `<span style=\"opacity: 0;\">█</span>⏐`;}
+		for (i = 0;i<z;i++) out += `<span style='opacity: 0;'>█</span>⏐`;}
 	return `${out}`;
 };
 
 window.SFC = function() {
 	const V=State.variables;
-	if (V.SF.MercCon.CanAttend === -1) {return `The Colonel`;}
-	else {
-		//if (V.SF.Facility.LCActive > 0) {return `Lieutenant Colonel ${SlaveFullName(V.SF.Facility.LC)}`;}
-		return `a designated soldier`;}
+	if (V.SF.MercCon.CanAttend === -1) {
+		return `The Colonel`;
+	} else {
+		/*if (V.SF.Facility.LCActive > 0) {
+		 * return `Lieutenant Colonel ${SlaveFullName(V.SF.Facility.LC)}`;
+		 }*/
+		return `a designated soldier`;
+	}
 };
 
 window.SFCR = function() {
-	const V=State.variables, C=V.SF.Colonel;
-	if (C.Status <= 19) {return `boss`;}
-	else if (C.Status <= 39) {return `friend`;}
-	else {return `fuckbuddy`;}
+	const V = State.variables, C = V.SF.Colonel;
+	if (C.Status <= 19) {
+		return `boss`;
+	} else if (C.Status <= 39) {
+		return `friend`;
+	} else {
+		return `fuckbuddy`;
+	}
 };
 
 window.Interactions = function() {
-	"use strict"; let choice=``, time=``;
-	const V=State.variables, C=V.SF.Colonel;
+	"use strict"; let choice = ``, time = ``;
+	const V = State.variables, C = V.SF.Colonel;
 	if (V.SF.Gift > 0) {
-		if (V.choice == 1) {
+		if (V.choice === 1) {
 			choice +=`${V.SF.Caps} is turning over spare capital in tribute this week. `;
 			if (V.SF.MercCon.CanAttend === -1 && (C.Talk + C.Fun !== 1)) {
-			 choice += `"I think I can find <span class='yellowgreen'>${cashFormat(Math.ceil(V.CashGift))}</span> for you, boss."`;
+				choice += `"I think I can find <span class='yellowgreen'>${cashFormat(Math.ceil(V.CashGift))}</span> for you, boss."`;
 			} else {
-			 choice += `"We can spare <span class='yellowgreen'>${cashFormat(Math.ceil(V.CashGift))}</span> in tribute this week, boss".`; }
-		} else if (V.choice == 2) {
+				choice += `"We can spare <span class='yellowgreen'>${cashFormat(Math.ceil(V.CashGift))}</span> in tribute this week, boss".`;
+			}
+		} else if (V.choice === 2) {
 			choice += `${V.SF.Caps} will be throwing a military parade this week. `;
 			if (V.SF.MercCon.CanAttend === -1 && (C.Talk + C.Fun !== 1)) {
-			choice += `"I expect the <span class='green'>public to enjoy</span> the parade, boss."`;
+				choice += `"I expect the <span class='green'>public to enjoy</span> the parade, boss."`;
 			} else {
-			choice += `"I'll have plans for an <span class='green'>popular parade</span> on your desk, boss".`; }
-		} else if (V.choice == 3) {
+				choice += `"I'll have plans for an <span class='green'>popular parade</span> on your desk, boss".`;
+			}
+		} else if (V.choice === 3) {
 			choice += `${V.SF.Caps} will be conducting corporate sabotage on rival arcologies' businesses. `;
 			if (V.SF.MercCon.CanAttend === -1 && (C.Talk + C.Fun !== 1)) {
-			choice += `"Our interests should see a <span class='yellowgreen'>big boost,</span> boss."`;
+				choice += `"Our interests should see a <span class='yellowgreen'>big boost,</span> boss."`;
 			} else {
-			choice += `"Your <span class='yellowgreen'>arcology's business prospects should see an improvement</span> this week, boss".`; }
+				choice += `"Your <span class='yellowgreen'>arcology's business prospects should see an improvement</span> this week, boss".`;
+			}
 		}
-	} if (C.Talk + C.Fun > 0) time=`<br>The Colonel is busy for the rest of the week, so the Lieutenant Colonel will assist you.`;
+	} if (C.Talk + C.Fun > 0) time = `<br>The Colonel is busy for the rest of the week, so the Lieutenant Colonel will assist you.`;
 	return `${time} <br>${choice}`;
 };
 
 window.BadOutcome = function() {
-	"use strict"; const V=State.variables; let r =``;V.SF.Active=-2;
+	"use strict"; const V = State.variables; let r = ``; V.SF.Active = -2;
 	switch(V.SF.Colonel.Core) {
 		case "Shell-Shocked":
-			V.SF.BadOutcome="lockdown"; V.trinkets.push("${t} explosives detonator");
-			r +=`Unnerved by your ever-increasing influence over your men and undercutting of her authority, The Colonel uses heavy explosives at Midnight to seal off The Firebase from your access. When you step off of your express elevator, you are met not with two guards, but several armed proximity mines next to an incredibly thick wall of smoking rubble. No doubt there are machine gun nests, anti-tank nests, and lots more proximity mines just waiting for you on the other side, should you somehow get through the wall of debris.`;
-			r+=`<br>The ${V.SF.Lower} still deploys into the old world to plunder as it pleases, but no longer for you. You receive no money from their exploits, and their total defiance and independence of you is a permanent stain on your reputation. Of course, you'll never have the needed military power to dislodge them, especially with all the redundant fortifications, crossfire envelopes, and myriad traps that paranoid bitch had built around each entrance ever since she went rouge. Trying to sabotage certain support beams from above to make the Firebase facility collapse in on itself could easily cause enough damage to topple other parts of the arcology too, and such a thing would be very difficult to cover up. In other words, you're stuck with them. The Firebase has become a permanent tumor on your Arcology and good name.`;
+			V.SF.BadOutcome = "lockdown"; V.trinkets.push("${t} explosives detonator");
+			r += `Unnerved by your ever-increasing influence over your men and undercutting of her authority, The Colonel uses heavy explosives at Midnight to seal off The Firebase from your access. When you step off of your express elevator, you are met not with two guards, but several armed proximity mines next to an incredibly thick wall of smoking rubble. No doubt there are machine gun nests, anti-tank nests, and lots more proximity mines just waiting for you on the other side, should you somehow get through the wall of debris.`;
+			r += `<br>The ${V.SF.Lower} still deploys into the old world to plunder as it pleases, but no longer for you. You receive no money from their exploits, and their total defiance and independence of you is a permanent stain on your reputation. Of course, you'll never have the needed military power to dislodge them, especially with all the redundant fortifications, crossfire envelopes, and myriad traps that paranoid bitch had built around each entrance ever since she went rouge. Trying to sabotage certain support beams from above to make the Firebase facility collapse in on itself could easily cause enough damage to topple other parts of the arcology too, and such a thing would be very difficult to cover up. In other words, you're stuck with them. The Firebase has become a permanent tumor on your Arcology and good name.`;
 			break;
 		case "Cruel":
-			V.SF.BadOutcome="Revolt"; V.trinkets.push("${t} dog tags"); repX((0 - V.rep), "specialForces");
-			V.arcologies[0].prosperity -= 50; V.ASlaves=49; cashX(-10000, "specialForces");
-			V.ACitizens=751; V.menials = 0; V.researchLab.menials = 0;
+			V.SF.BadOutcome = "Revolt"; V.trinkets.push("${t} dog tags"); repX((0 - V.rep), "specialForces");
+			V.arcologies[0].prosperity -= 50; V.ASlaves = 49; cashX(-10000, "specialForces");
+			V.ACitizens = 751; V.menials = 0; V.researchLab.menials = 0;
 			V.researchLab.hired = 0; V.fuckdolls = 0; V.menialBioreactors = 0;
 			V.activeUnits = 0; V.secBots.troops = 0; V.createdSlavesUnits = 0;
 			V.createdMilitiaUnits = 0; V.createdMercUnits = 0;
-			r+=`<br>The ${V.SF.Lower} still deploys into the old world to plunder as it pleases, but no longer for you. You receive no money from their exploits, and their total defiance and independence of you is a permanent stain on your reputation. Of course, you'll never have the needed military power to dislodge them, especially with all the redundant fortifications, crossfire envelopes, and myriad traps that paranoid bitch had built around each entrance ever since she went rouge. Trying to sabotage certain support beams from above to make the Firebase facility collapse in on itself could easily cause enough damage to topple other parts of the arcology too, and such a thing would be very difficult to cover up. In other words, you're stuck with them. The Firebase has become a permanent tumor on your Arcology and good name.`;
+			r += `<br>The ${V.SF.Lower} still deploys into the old world to plunder as it pleases, but no longer for you. You receive no money from their exploits, and their total defiance and independence of you is a permanent stain on your reputation. Of course, you'll never have the needed military power to dislodge them, especially with all the redundant fortifications, crossfire envelopes, and myriad traps that paranoid bitch had built around each entrance ever since she went rouge. Trying to sabotage certain support beams from above to make the Firebase facility collapse in on itself could easily cause enough damage to topple other parts of the arcology too, and such a thing would be very difficult to cover up. In other words, you're stuck with them. The Firebase has become a permanent tumor on your Arcology and good name.`;
 			break;
 		case "Cruel and Psychopathic":
-			V.SF.BadOutcome="Revolt"; V.trinkets.push("${t} dog tags"); repX((0 - V.rep), "specialForces");
+			V.SF.BadOutcome = "Revolt"; V.trinkets.push("${t} dog tags"); repX((0 - V.rep), "specialForces");
 			r += `<br>Finally fed up with your constant intrusions into her territory and crew, The Colonel riles up her people for an utterly ferocious rebellion. The promises of rape and plunder and dominion over some of the wealthiest tenants in the entire Free City (and their world-class slaves) are all that's needed to give the selfish lot of them a nearly unshakable resolve in the task of delivering their overlord Her most coveted prize: You.`;
 			r += `<br>It is now midnight. The lights are the first thing they disable, as they still have the excellent night vision equipment you purchased for them. Some of your citizens start panicking almost immediately at the sudden blackout; this is very reminiscent of the Daughters of Liberty attack that still haunts many of their memories. Things like this were never supposed to happen again. You had promised them that you'd create an army that would protect them...`;
 			r += `<br>Her army vanguard strikes fast and hard throughout the main Plaza, cutting through your security personnel, defensive platoons, and drones with an ease that stinks of months of careful planning and study. Your defensive platoons, veterans of many Battles, are outmaneuvered at every turn; their hidden ammunition caches are found empty, their communications networks are mysteriously scrambled, and key chokepoints are found to be booby-trapped before your men can even get to them; their well-rehearsed arcology defense routines have gone to ash. Assuming you ever get a chance to speak to The Colonel again, you would ask if her betrayal was actually inevitable rather than something you triggered.`;
@@ -516,7 +616,7 @@ window.BadOutcome = function() {
 			r += `<br>The Colonel's body was never found.`;
 			break;
 		case "Kind":
-			V.SF.BadOutcome="Exodus"; V.trinkets.push("${t} gift card"); V.menials += 73;
+			V.SF.BadOutcome = "Exodus"; V.trinkets.push("${t} gift card"); V.menials += 73;
 			cashX(55000, "specialForces");
 			r += `Your Colonel has had enough of your meddling. In her eyes, you've broken faith with her. She asked one thing of you in return for her full support, and you could not even give her that.`;
 			r += `<br>At midnight, a great mechanized convoy, the biggest you've seen in a long while, streams out of your Arcology. Troop Carriers, Aircraft, Heavy Trucks, and other war machines of varying sizes pour out of the Firebase in tight formation. The Colonel is refusing your calls, and you know it would be ill advised to go out there yourself or to try to stop them with force. The many bandits and mercenary groups that the convoy will inevitably pass by will probably feel this way as well. You have no idea where they are going or how they will end up, but with their wealth and weaponry, you are not worried.`;
@@ -528,257 +628,325 @@ window.BadOutcome = function() {
 };
 
 window.UnitText = function(input) {
-	"use strict"; const V=State.variables,T=State.temporary,S=V.SF.Squad; let r =``;
+	"use strict"; const V = State.variables, S = V.SF.Squad; let r =``;
+	//Sorted by case
+	let appear = `is currently constructed in a haphazard fashion.`;
+	let barracks = `Soldiers' cots are mixed in with weapons crates and ammunition.`;
+	let slave = `Cages for processing slaves lie off to one side,`;
+	let common = `and in the center is a common area with tables for soldiers to gather around for meals or rowdy conversations.`;
+	let garage = ``, drone = ``, hangar = ``, launch = ``, artillery = ``;
+	let comms = ``, training = ``;
+
+	const Quantity = `the ${num(S.Troops)} members of ${V.SF.Lower}`;
+
+	let weapons = `The weapons are mostly worn rifles that have already seen years of service before ${V.SF.Lower} acquired them.`;
+	let armor1 = `The body armor is enough to stop smaller calibers, but nothing serious.`;
+	let radio = ``, helmets = ``, ammo0 = ``, uniforms = ``, special = ``;
+	let exo = ``;
+
+	let amphet = ``, phen = ``, steroid = ``, downer = ``, concen = ``;
+	let stimpack = ``, stabilizer = ``;
+
+	let a = `have been recommissioned for use by ${V.SF.Lower}`, b = `.`, c = ``;
+	let d = ``, e = ``, f = ``, g = ``, h = ``, i = ``, j = ``, k = ``;
+
+	let activate = `has been recommissioned for use by ${V.SF.Lower}. They`;
+	let mechanics = `, mechanics are methodically checking the recent purchases for battle-readiness`;
+	let MG = `120 mm main gun is enough to handle the majority of opponents around the Free Cities.`;
+	let engine1 = ``, armor2 = ``, armor22 = ``, ammo1 = ``, mg = ``;
+	let fireC0 = ``, fireC1 = ``, fireC2 = ``, fireC3 = ``, turret = ``;
+
+	let B = `has been recommissioned for use by ${V.SF.Lower}. They`;
+	let C = `, mechanics are giving the new purchases a final tuneup`;
+	let squad = `a squad`, G1 = `20`, G2 = `in a firefight`;
+	let e0 = `The engine has been`, engine3 = ``, armor3 = ``, tires = ``;
+	let m1 = ``, m2 = ``, pod1 = ``, pod2 = ``;
+
+	let b1 = `has been sold to ${V.SF.Lower} through back channels to support a failing Old World nation. The tank is so large it cannot fit inside the garage, and has`;
+	let c1 = ``, engines4 = `. Two engines power the left and right sides of the tank separately, leaving it underpowered and slow`;
+	let gun0 = ``, gun1 = ``, gun2 = `an undersized main gun and makeshift firing system from a standard battle tank`;
+	let armor5 = ``, armor6 = ``, cannon = ``, laser = ``, PGTframe = ``;
+
+	let W1 = `only armed`, W2 = `;`, W3 = `a poor weapon against flying targets, but enough to handle ground forces`;
+	let group = `A small group of attack VTOL have been recommissioned for use by ${V.SF.Lower}, enough to make up a squadron`;
+	let engines = ``, TAI = ``, lock = ``, support = ``, stealth = ``;
+	let scramble = ``, PAI = ``;
+
+	let Num = `number`, type = `tiltrotor`, capacity = `small platoon or 15`;
+	let engines0 = ``, engines01 = ``, Radar = ``, Armor = ``, landing = ``;
+	let miniguns = ``, counter = ``;
+
+	let engine20 = `ramjet engines in the atmosphere that can reach Mach 10`;
+	let b5 = `has been purchased from an insolvent Old World nation. It `;
+	let shield = ``, camera = ``, efficiency = ``, camera2 = ``, drag = ``;
+	let crew = ``, engine2 = ``, skin = ``;
+
+	let activate2 = `has been recommissioned for use by ${V.SF.Lower}. Currently, it `;
+		let barrels = `Miniguns and Gatling cannons line`, distance = `, though the distance to ground targets renders the smaller calibers somewhat less useful`;
+	let b4 = ``, c2 = ``, fuel = ``, GS_Speed = ``, countermeasures = ``, ammunition = ``, DFA = ``, autocannon = ``;
+
+	let loc1 = `An unused science satellite has been purchased from an Old World nation. While currently useless, it holds potential to be a powerful tool.`;
+	let gyro = ``, telemetry = ``, thrusters = ``, solar = ``, surviv = ``;
+	let laser1 = ``, heat = ``, reactor = ``, lens = ``, kin = ``;
+
+	let loc = `has been purchased from a crumbling Old World nation. It`;
+	let power = `Large batteries mounted in oversized shoulders power the robot for up to ten minutes of use, though they make for large targets.`;
+	let knife = `simply a 8.5 meter long knife, though additional weapons are under development.`;
+	let armor8 = ``, actuator = ``, cannon1 = ``, heatsink = ``, ammo2 = ``;
+	let missile = ``;
+
+let a4 = `A cruise missile launch site has been constructed near the base of`;
+let b2 = `outdated, something quickly rigged together to give the launch site something to fire in the case of an attack`;
+let c8 = ``, d1 = ``, e1 = ``, f1 = ``, g1 = ``, h1 = ``;
+
+let recom1 = `has been recommissioned from the Old World for ${V.SF.Lower}. It`;
+let jets = `Formerly mothballed strike jets`, loc2 = ``, radar = ``, AAG = ``;
+let prop = ``, torp = ``, armor9 = ``, power1 = ``, scramble1 = ``;
+
+let recom = `has been recommissioned from the old world, and`;
+let reactor0 = `Because diesel engines provide power and breathing oxygen is kept in pressurized canisters, the sub must frequently surface.`;
+let reactor1 = ``, cal = ``, hull = ``, tubes = ``, torpedoes = ``, sonar = ``;
+let control = ``, missiles = ``;
+
+let recom2 = `; has been recommissioned for use by ${V.SF.Lower}. It`;
+let tons = `200`, skirt = ``, guns = ``, guns2 = ``, fans = ``, speed = ``;
+let turbines = ``, armor10 = ``, ramps = ``, HATframe = ``, loadout = ``;
+
 	switch(input) {
 		case 'firebase':
-			let appear=`is currently constructed in a haphazard fashion.`, barracks=`Soldiers' cots are mixed in with weapons crates and ammunition.`, slave=`Cages for processing slaves lie off to one side,`, common=`and in the center is a common area with tables for soldiers to gather around for meals or rowdy conversations.`, garage=``, drone=``, hangar=``, launch=``, artillery=``, comms=``, training=``;
 			if (S.Firebase >= 0) { r += `<br>''Firebase:''`;
-				if (S.Firebase >= 1) appear=`has had some organization put into it.`; barracks=`The majority of weapons, armor, and ammunition have been separated from the soldiers' cots into their own armory.`; garage=`A section near the outer wall of the arcology has been converted to a garage with an adjoining vehicle maintenance bay`; drone=`.`;	if (V.terrain === "oceanic") garage += ` for inter-arcology travel`;
-				if (S.Firebase >= 2) barracks=`A barracks has been constructed near the armory, allowing soldiers a quieter place to sleep and store their personal spoils.`; drone=`; as well as a facility for the storage, maintenance, and deployment of armed combat drones.`;
-				if (S.Firebase >= 3) appear=`has become more permanent.`; barracks=`A command center has been constructed near the barracks and armory, allowing for additional support personnel.`;
-				if (S.Firebase >= 4) hangar=`Hangar space for storing and repairing aircraft has been converted from unused space on the other side of the garage.`;
+				if (S.Firebase >= 1) appear = `has had some organization put into it.`; barracks = `The majority of weapons, armor, and ammunition have been separated from the soldiers' cots into their own armory.`; garage = `A section near the outer wall of the arcology has been converted to a garage with an adjoining vehicle maintenance bay`; drone = `.`;	if (V.terrain === "oceanic") garage += ` for inter-arcology travel`;
+				if (S.Firebase >= 2) barracks = `A barracks has been constructed near the armory, allowing soldiers a quieter place to sleep and store their personal spoils.`; drone = `; as well as a facility for the storage, maintenance, and deployment of armed combat drones.`;
+				if (S.Firebase >= 3) appear = `has become more permanent.`; barracks = `A command center has been constructed near the barracks and armory, allowing for additional support personnel.`;
+				if (S.Firebase >= 4) hangar = `Hangar space for storing and repairing aircraft has been converted from unused space on the other side of the garage.`;
 				if (S.Firebase >= 5)
-					appear=`is nearing the appearance of a military base.`; launch=`The rest of the firebase has been designated for special projects.`; artillery=`Artillery batteries are set around the base of the arcology.`; if (V.terrain === "oceanic" || V.terrain === "marine") launch += ` A Naval Yard has been constructed in the waters near the arcology.`;
-				if (S.Firebase >= 6) common=`and in the center is a common area for recreation, including a small movie theater and a mess hall.`;
-				if (S.Firebase >= 7) {slave=`A slave detention facility has been sectioned off to one side`;
+					appear = `is nearing the appearance of a military base.`; launch = `The rest of the firebase has been designated for special projects.`; artillery = `Artillery batteries are set around the base of the arcology.`; if (V.terrain === "oceanic" || V.terrain === "marine") launch += ` A Naval Yard has been constructed in the waters near the arcology.`;
+				if (S.Firebase >= 6) common = `and in the center is a common area for recreation, including a small movie theater and a mess hall.`;
+				if (S.Firebase >= 7) {slave = `A slave detention facility has been sectioned off to one side`;
 					if (V.SF.Depravity > 1.5) slave += ` emanating the sounds of rape and torture`;
 					slave += `;`;}
-				if (S.Firebase >= 8) { appear=`has become a fully fledged military base.`; comms=`A Free City-wide communication network for ${V.SF.Lower} has been constructed to facilitate faster responses and efficient monitoring of the surrounding area.`; }
-				if (S.Firebase >= 9) training=`A high-tech killhouse has been constructed to aid in soldier training.`;
-				if (S.Firebase >= 10) artillery=`Railgun artillery batteries are set around the base of the arcology, capable of accurately destroying enemies an absurd distance away.`;
+				if (S.Firebase >= 8) { appear = `has become a fully fledged military base.`; comms = `A Free City-wide communication network for ${V.SF.Lower} has been constructed to facilitate faster responses and efficient monitoring of the surrounding area.`; }
+				if (S.Firebase >= 9) training = `A high-tech killhouse has been constructed to aid in soldier training.`;
+				if (S.Firebase >= 10) artillery = `Railgun artillery batteries are set around the base of the arcology, capable of accurately destroying enemies an absurd distance away.`;
 				return `${r} The firebase ${appear} ${barracks} ${comms} ${training} ${slave} ${common} ${garage}${drone} ${hangar} ${launch} ${artillery}`;
 			} break;
 		case 'troop': r += `<br>&nbsp;The large dormitories are`;
-			const Quantity=`the ${num(S.Troops)} members of ${V.SF.Lower}`;
 			if (S.Troops < 100) {return `${r} sparsely occupied, ${Quantity} residing within them concentrating together in a corner. The hundreds of empty beds and lockers visibly herald the future`;}
 			else if (S.Troops < 400) {return `${r} lightly occupied, with ${Quantity} starting to spread out across them`;}
 			else if (S.Troops < 800) {return `${r} moderately occupied, though ${Quantity} residing within have a considerable amount of extra room`;}
 			else if (S.Troops < 1500) {return `${r} well-occupied, and ${Quantity} residing within have started to form small cliques based on section and row`;}
 			else {return `${r} near capacity, and ${Quantity} often barter their personal loot, whether it be monetary or human, for the choicest bunks`;}
 			break;
-		case 'armory':
-			let weapons=`The weapons are mostly worn rifles that have already seen years of service before ${V.SF.Lower} acquired them.`, armor1=`The body armor is enough to stop smaller calibers, but nothing serious.`, radio=``, helmets=``, ammo0=``, uniforms=``, special=``, exo=``;
-			if (S.Armoury >= 0) {r += `<br><br>''Armory:''<br>`; radio=`Radios have been wired into the soldiers helmets`; helmets=`.`;
-				if (S.Armoury >= 2) helmets=` and a HUD has been integrated into the soldier's eyewear.`;
-				if (S.Armoury >= 3) ammo0=`Tactical vests have been provided, allowing soldiers to carry additional ammo.`;
-				if (S.Armoury >= 4) armor1=`The body armor is a newer variant, able to stop small arms fire and protect against shrapnel.`;
-				if (S.Armoury >= 5) weapons=`The weapons are modern rifles and sidearms, putting ${V.SF.Lower} on par with rival mercenary outfits.`;
-				if (S.Armoury >= 6) uniforms=`New uniforms have been distributed that are more comfortable and made of breathable fabric to keep soldiers from overheating.`;
-				if (S.Armoury >= 7) special=`Specialized weaponry is available for many roles, allowing more flexibility in planning.`;
-				if (S.Armoury >= 8) helmets=`and a HUD and camera display have been integrated into soldiers' eyewear, enabling accurate aim around corners or from behind cover`;
-				if (S.Armoury >= 9) exo=`An exosuit has been developed to reduce the amount of weight soldiers carry, increase lifting strength, and move faster in combat.`;
-				if (S.Armoury >= 10) weapons=`Cutting-edge weaponry is available to ${V.SF.Lower}, far outpacing the ability of rival mercenary outfits.`;
+		case 'armoury':
+			if (S.Armoury >= 0) { r += `<br><br>''Armory:''<br>`; radio = `Radios have been wired into the soldiers helmets`; helmets = `.`;
+				if (S.Armoury >= 2) helmets = ` and a HUD has been integrated into the soldier's eyewear.`;
+				if (S.Armoury >= 3) ammo0 = `Tactical vests have been provided, allowing soldiers to carry additional ammo.`;
+				if (S.Armoury >= 4) armor1 = `The body armor is a newer variant, able to stop small arms fire and protect against shrapnel.`;
+				if (S.Armoury >= 5) weapons = `The weapons are modern rifles and sidearms, putting ${V.SF.Lower} on par with rival mercenary outfits.`;
+				if (S.Armoury >= 6) uniforms = `New uniforms have been distributed that are more comfortable and made of breathable fabric to keep soldiers from overheating.`;
+				if (S.Armoury >= 7) special = `Specialized weaponry is available for many roles, allowing more flexibility in planning.`;
+				if (S.Armoury >= 8) helmets = `and a HUD and camera display have been integrated into soldiers' eyewear, enabling accurate aim around corners or from behind cover`;
+				if (S.Armoury >= 9) exo = `An exosuit has been developed to reduce the amount of weight soldiers carry, increase lifting strength, and move faster in combat.`;
+				if (S.Armoury >= 10) weapons = `Cutting-edge weaponry is available to ${V.SF.Lower}, far outpacing the ability of rival mercenary outfits.`;
 				return `${r} The armory holds soldiers' weapons and gear while not in training or combat. ${weapons} ${special} ${armor1} ${radio}${helmets} ${ammo0} ${uniforms} ${exo}`;
-			} break;
+			}
+			break;
 		case 'drugs':
-			let amphet=``, phen=``, steroid=``, downer=``, concen=``, stimpack=``, stabilizer=``;
-			if (S.Drugs >= 0) { r += `<br><br>''Drug Lab:''`; amphet=`Amphetamines have been added to the cocktail at a low dosage to act as a stimulant, physical performance enhancer, cognition control enhancer. Some side-effects exist.`;
-				if (S.Drugs >= 2) phen=`Phencyclidine has been added to the cocktail at a low dosage as a dissociative psychotropic for soldiers in battle to introduce feelings of detachment, strength and invincibility, and aggression. Some side-effects reduce the tolerable dosage before soldiers go on uncontrollable violent outbreaks.`;
-				if (S.Drugs >= 3) steroid=`Testosterone is being produced for soldiers in training as a natural muscle growth stimulant and to invoke aggression.`;
-				if (S.Drugs >= 4) downer=`Zaleplon is being produced as a downer to counteract the battle cocktail and encourage rest before combat.`;
-				if (S.Drugs >= 5) concen=`Methylphenidate has been added to the cocktail as a stimulant and to improve soldier concentration.`;
-				if (S.Drugs >= 6) phen=`A phencyclidine-based drug has been added to the cocktail as a dissociative psychotropic for soldiers in battle to introduce controllable feelings of detachment, strength and invincibility, and aggression.`;
-				if (S.Drugs >= 7) steroid=`Low levels of anabolic steroids are being produced for soldiers in training to stimulate muscle growth and invoke aggression.`;
-				if (S.Drugs >= 8) amphet=`Diphenylmethylsulfinylacetamide has been added to the cocktail to counteract the effects of sleep deprivation and promote alertness.`;
-				if (S.Drugs >= 9) stimpack=`A stimpack of the battle cocktail is being given to soldiers in battle to take if the original dose wears off before the battle is over.`;
-				if (S.Drugs >= 10) stabilizer=`A stabilizer has been added to the battle cocktail that helps tie effects together while reducing side-effects, leading to an effectively safe supersoldier drug.`;
+			if (S.Drugs >= 0) { r += `<br><br>''Drug Lab:''`; amphet = `Amphetamines have been added to the cocktail at a low dosage to act as a stimulant, physical performance enhancer, cognition control enhancer. Some side-effects exist.`;
+				if (S.Drugs >= 2) phen = `Phencyclidine has been added to the cocktail at a low dosage as a dissociative psychotropic for soldiers in battle to introduce feelings of detachment, strength and invincibility, and aggression. Some side-effects reduce the tolerable dosage before soldiers go on uncontrollable violent outbreaks.`;
+				if (S.Drugs >= 3) steroid = `Testosterone is being produced for soldiers in training as a natural muscle growth stimulant and to invoke aggression.`;
+				if (S.Drugs >= 4) downer = `Zaleplon is being produced as a downer to counteract the battle cocktail and encourage rest before combat.`;
+				if (S.Drugs >= 5) concen = `Methylphenidate has been added to the cocktail as a stimulant and to improve soldier concentration.`;
+				if (S.Drugs >= 6) phen = `A phencyclidine-based drug has been added to the cocktail as a dissociative psychotropic for soldiers in battle to introduce controllable feelings of detachment, strength and invincibility, and aggression.`;
+				if (S.Drugs >= 7) steroid = `Low levels of anabolic steroids are being produced for soldiers in training to stimulate muscle growth and invoke aggression.`;
+				if (S.Drugs >= 8) amphet = `Diphenylmethylsulfinylacetamide has been added to the cocktail to counteract the effects of sleep deprivation and promote alertness.`;
+				if (S.Drugs >= 9) stimpack = `A stimpack of the battle cocktail is being given to soldiers in battle to take if the original dose wears off before the battle is over.`;
+				if (S.Drugs >= 10) stabilizer = `A stabilizer has been added to the battle cocktail that helps tie effects together while reducing side-effects, leading to an effectively safe supersoldier drug.`;
 				return `${r} A drug lab has been established to increase the effectiveness of ${V.SF.Lower}'s soldiers. Many of these chemicals are mixed into a single 'battle cocktail' to be taken before combat. ${amphet} ${phen} ${concen} ${steroid} ${downer} ${stimpack} ${stabilizer}`;
 			} break;
-		case 'UAV': if(S.Firebase >= 2 && S.Drones >= 1) { r += `<br><br>''Drone Bay:''`;
-			let a=`have been recommissioned for use by ${V.SF.Lower}`, b=`.`, c=``, d=``, e=``, f=``, g=``, h=``, i=``, j=``, k=``;
-			if (S.Drones >= 2) a=`equipped with missiles are resting on one side of the drone bay`; b=`; as well as destroying the occasional target.`;
-			if (S.Drones >= 3) c=`A fleet of`; d=`large delivery quadcopters have been converted for military service to support ground forces as combat drones.`;
-			if (S.Drones >= 4) d=`combat drones take up the rest of the space in the drone bay. They have a`; e=`small automatic rifle`; f=`mounted to the underside.`;
-			if (S.Drones >= 5) g=`Armor has been added to protect vulnerable components from small arms fire.`;
-			if (S.Drones >= 6) h=`The fleet's batteries have been replaced with higher capacity models, increasing the functional time spent in combat.`;
-			if (S.Drones >= 7) i=`The propellers and motors have been upgraded, increasing maneuverability and speed.`;
-			if (S.Drones >= 8) j=`The drone control signal has been boosted and encrypted, giving the drones a greater range and protecting against electronic warfare.`;
-			if (S.Drones >= 9) e=`light machine gun`;
-			if (S.Drones >= 10) k=`A drone-to-drone network has been installed, allowing drones to swarm, maneuver, and attack targets autonomously.`;
-			return `${r} Surveillance drones ${a}. During combat, they supply aerial intel to commanders and act as the communications network for ground forces${b} ${c} ${d} ${e} ${f} ${g} ${h} ${i} ${j} ${k}`;
+		case 'UAV':
+			if(S.Firebase >= 2 && S.Drones >= 1) { r += `<br><br>''Drone Bay:''`;
+				if (S.Drones >= 2) a = `equipped with missiles are resting on one side of the drone bay`; b = `; as well as destroying the occasional target.`;
+				if (S.Drones >= 3) c = `A fleet of`; d = `large delivery quadcopters have been converted for military service to support ground forces as combat drones.`;
+				if (S.Drones >= 4) d = `combat drones take up the rest of the space in the drone bay. They have a`; e = `small automatic rifle`; f = `mounted to the underside.`;
+				if (S.Drones >= 5) g = `Armor has been added to protect vulnerable components from small arms fire.`;
+				if (S.Drones >= 6) h = `The fleet's batteries have been replaced with higher capacity models, increasing the functional time spent in combat.`;
+				if (S.Drones >= 7) i = `The propellers and motors have been upgraded, increasing maneuverability and speed.`;
+				if (S.Drones >= 8) j = `The drone control signal has been boosted and encrypted, giving the drones a greater range and protecting against electronic warfare.`;
+				if (S.Drones >= 9) e = `light machine gun`;
+				if (S.Drones >= 10) k = `A drone-to-drone network has been installed, allowing drones to swarm, maneuver, and attack targets autonomously.`;
+				return `${r} Surveillance drones ${a}. During combat, they supply aerial intel to commanders and act as the communications network for ground forces${b} ${c} ${d} ${e} ${f} ${g} ${h} ${i} ${j} ${k}`;
 			} break;
 		case 'AV':
-			let b=`has been recommissioned for use by ${V.SF.Lower}. They`, c=`, mechanics are methodically checking the recent purchases for battle-readiness`, MG=`120 mm main gun is enough to handle the majority of opponents around the Free Cities.`, engine1=``, armor2=``, armor22=``, ammo1=``, mg=``, fireC0=``, fireC1=``, fireC2=``, fireC3=``, turret=``;
 			if (S.AV >= 1) { r += `<br>&nbsp;&nbsp;''Assault:''`;
-				if (S.AV >= 2) engine1=`The engine1 has been overhauled, allowing much faster maneuvering around the battlefield.`; b=``; c=``;
-				if (S.AV >= 3) armor2=`A composite ceramic armor has replaced the original, offering much greater protection from attacks.`;
-				if (S.AV >= 4) ammo1=`The tanks have been outfitted with additional types of ammo for situational use.`;
-				if (S.AV >= 5) mg=`A remote-controlled .50 cal machine gun has been mounted on the turret to handle infantry and low-flying aircraft.`;
-				if (S.AV >= 6) fireC0=`A fire-control system`; fireC3=`been installed, guaranteeing`; fireC2=`has`; fireC1=`accurate fire.`;
-				if (S.AV >= 7) fireC2=`and an autoloader have`; fireC1=`rapid, accurate fire while separating the crew from the stored ammunition in the event the ammo cooks off.`;
-				if (S.AV >= 8) armor22=`A reactive armor system has been added, giving the tank an additional, if temporary, layer of protection.`;
-				if (S.AV >= 9) turret=`The turret has been massively redesigned, lowering the tank profile and increasing the efficiency of the mechanisms within.`;
-				if (S.AV >= 10) MG=`140 mm main gun can quash anything even the greatest Old World nations could muster.`;
-				return `${r} A fleet of main battle tanks ${b} are parked in the garage${c}. ${turret} The ${MG} ${ammo1} ${mg} ${fireC0} ${fireC2} ${fireC3} ${fireC1} ${engine1} ${armor2} ${armor22}`;
+				if (S.AV >= 2) engine1 = `The engine1 has been overhauled, allowing much faster maneuvering around the battlefield.`; activate = ``; mechanics = ``;
+				if (S.AV >= 3) armor2 = `A composite ceramic armor has replaced the original, offering much greater protection from attacks.`;
+				if (S.AV >= 4) ammo1 = `The tanks have been outfitted with additional types of ammo for situational use.`;
+				if (S.AV >= 5) mg = `A remote-controlled .50 cal machine gun has been mounted on the turret to handle infantry and low-flying aircraft.`;
+				if (S.AV >= 6) fireC0 = `A fire-control system`; fireC3 = `been installed, guaranteeing`; fireC2 = `has`; fireC1 = `accurate fire.`;
+				if (S.AV >= 7) fireC2 = `and an autoloader have`; fireC1 = `rapid, accurate fire while separating the crew from the stored ammunition in the event the ammo cooks off.`;
+				if (S.AV >= 8) armor22 = `A reactive armor system has been added, giving the tank an additional, if temporary, layer of protection.`;
+				if (S.AV >= 9) turret = `The turret has been massively redesigned, lowering the tank profile and increasing the efficiency of the mechanisms within.`;
+				if (S.AV >= 10) MG = `140 mm main gun can quash anything even the greatest Old World nations could muster.`;
+				return `${r} A fleet of main battle tanks ${activate} are parked in the garage${mechanics}. ${turret} The ${MG} ${ammo1} ${mg} ${fireC0} ${fireC2} ${fireC3} ${fireC1} ${engine1} ${armor2} ${armor22}`;
 			} break;
 		case 'TV':
-			let B=`has been recommissioned for use by ${V.SF.Lower}. They`, C=`, mechanics are giving the new purchases a final tuneup`, squad=`a squad`, G1=`20`, G2=`in a firefight`, e0=`The engine has been`, engine3=``, armor3=``, tires=``, m1=``, m2=``, pod1=``, pod2=``;
 			if (S.TV >= 1) { r += `<br>&nbsp;&nbsp;''Transport:''`;
-				if (S.TV >= 2) engine3=`${e0} overhauled, allowing for higher mobility.`; C=``; B=``;
-				if (S.TV >= 3) armor3=`Composite armor has been bolted to the exterior, increasing the survivability of an explosive attack for the crew and passengers.`;
-				if (S.TV >= 4) tires=`The tires have been replaced with a much more durable version that can support a heavier vehicle.`;
-				if (S.TV >= 5) m1=`An automatic missile defense system has been installed,`; m2=`targeting any guided missiles with laser dazzlers and deploying a smokescreen.`;
-				if (S.TV >= 6) pod1=`An anti-tank missile pod`; pod2=`has been installed on the side of the turret.`;
-				if (S.TV >= 7) G1=`25`; G2=`by attacking enemies through cover and destroying light armor`;
-				if (S.TV >= 8) pod2=`and an anti-aircraft missile pod have been installed on either side of the turret.`;
-				if (S.TV >= 9) squad=`two squads`; armor3=``; m2=`destroying any incoming missiles with a high-powered laser. Some of the now redundant composite armor has been removed, and the reclaimed space allows for more passengers.`;
-				if (S.TV >= 10) engine3=`${e0} replaced with the newest model, allowing the vehicle to get in and out of the conflict extremely quickly.`;
+				if (S.TV >= 2) engine3 = `${e0} overhauled, allowing for higher mobility.`; C = ``; B = ``;
+				if (S.TV >= 3) armor3 = `Composite armor has been bolted to the exterior, increasing the survivability of an explosive attack for the crew and passengers.`;
+				if (S.TV >= 4) tires = `The tires have been replaced with a much more durable version that can support a heavier vehicle.`;
+				if (S.TV >= 5) m1 = `An automatic missile defense system has been installed,`; m2 = `targeting any guided missiles with laser dazzlers and deploying a smokescreen.`;
+				if (S.TV >= 6) pod1 = `An anti-tank missile pod`; pod2 = `has been installed on the side of the turret.`;
+				if (S.TV >= 7) G1 = `25`; G2 = `by attacking enemies through cover and destroying light armor`;
+				if (S.TV >= 8) pod2 = `and an anti-aircraft missile pod have been installed on either side of the turret.`;
+				if (S.TV >= 9) squad = `two squads`; armor3 = ``; m2 = `destroying any incoming missiles with a high-powered laser. Some of the now redundant composite armor has been removed, and the reclaimed space allows for more passengers.`;
+				if (S.TV >= 10) engine3 = `${e0} replaced with the newest model, allowing the vehicle to get in and out of the conflict extremely quickly.`;
 				return `A fleet of infantry fighting vehicles ${B} are parked in the garage${C}. The IFVs can carry ${squad} of 6 to a firezone. The ${G1} mm autocannon supports infantry ${G2}. ${pod1} ${pod2} ${engine3} ${armor3} ${tires} ${m1} ${m2}`;
-			} break;
+			}
+			break;
 		case 'PGT':
-			let b1=`has been sold to ${V.SF.Lower} through back channels to support a failing Old World nation. The tank is so large it cannot fit inside the garage, and has`, c1=``, engines4=`. Two engines power the left and right sides of the tank separately, leaving it underpowered and slow`, gun0=``, gun1=``, gun2=`an undersized main gun and makeshift firing system from a standard battle tank`, armor5=``, armor6=``, cannon=``, laser=``, PGTframe=``;
 			if (S.PGT >= 1) {r += `<br>&nbsp;''Prototype Goliath Tank:''`;
-				if (S.PGT >= 2) c1=`rests in`; b1=``; engines4=` and powered by their own engine, allowing the tank to travel with an unsettling speed for its massive bulk`;
-				if (S.PGT >= 3) gun0=`a railgun capable of`; gun1=`firing steel slugs`; gun2=`through one tank and into another`;
-				if (S.PGT >= 4) armor6=`reinforced, increasing survivability for the crew inside.`; armor5=`The armor has been`;
-				if (S.PGT >= 5) cannon=`A coaxial 30mm autocannon has been installed in the turret, along with automated .50 cal machine guns mounted over the front treads.`;
-				if (S.PGT >= 6) laser=`Laser anti-missile countermeasures have been installed, destroying any subsonic ordinance fired at the Goliath.`;
-				if (S.PGT >= 7) PGTframe=`The frame has been reinforced, allowing the Goliath to carry more armor and guns.`;
-				if (S.PGT >= 8) armor6=`redesigned with sloping and state-of-the-art materials, allowing the Goliath to shrug off even the most advanced armor5-piercing tank rounds.`;
-				if (S.PGT >= 9) gun1=`firing guided projectiles`;
-				if (S.PGT >= 10) gun0=`a twin-barreled railgun capable of rapidly`;
+				if (S.PGT >= 2) c1 = `rests in`; b1 = ``; engines4 = ` and powered by their own engine, allowing the tank to travel with an unsettling speed for its massive bulk`;
+				if (S.PGT >= 3) gun0 = `a railgun capable of`; gun1 = `firing steel slugs`; gun2 = `through one tank and into another`;
+				if (S.PGT >= 4) armor6 = `reinforced, increasing survivability for the crew inside.`; armor5 = `The armor has been`;
+				if (S.PGT >= 5) cannon = `A coaxial 30mm autocannon has been installed in the turret, along with automated .50 cal machine guns mounted over the front treads.`;
+				if (S.PGT >= 6) laser = `Laser anti-missile countermeasures have been installed, destroying any subsonic ordinance fired at the Goliath.`;
+				if (S.PGT >= 7) PGTframe = `The frame has been reinforced, allowing the Goliath to carry more armor and guns.`;
+				if (S.PGT >= 8) armor6 = `redesigned with sloping and state-of-the-art materials, allowing the Goliath to shrug off even the most advanced armor5-piercing tank rounds.`;
+				if (S.PGT >= 9) gun1 = `firing guided projectiles`;
+				if (S.PGT >= 10) gun0 = `a twin-barreled railgun capable of rapidly`;
 				return `A prototype Goliath tank ${b1}${c1} its own garage housing built outside the arcology. The massive bulk is spread out over 8 tracks, two for each corner of the tank${engines4}. The turret is equipped with ${gun0} ${gun1} ${gun2}. ${cannon} ${armor5} ${armor6} ${laser} ${PGTframe}`;
 			} break;
 		case 'AA':
-			let W1=`only armed`, W2=`;`, W3=`a poor weapon against flying targets, but enough to handle ground forces`, group=`A small group of attack VTOL have been recommissioned for use by ${V.SF.Lower}, enough to make up a squadron`, engines=``, TAI=``, lock=``, support=``, stealth=``, scramble=``, PAI=``;
-			if (S.AA >= 1) {r += `<br>&nbsp;&nbsp;''Assault:''`;
-				if (S.AA >= 2) W1=`armed`; W2=` and air-to-air missiles,`; W3=`a combination that can defend the arcology from enemy aircraft, as well as`; support=` support ground troops`;
-				if (S.AA >= 3) engines=`The engines have been tuned, allowing faster flight with greater acceleration.`;
-				if (S.AA >= 4) TAI=`An advanced targeting AI has been installed to handle all control of weapons, allowing much more efficient use of ammunition and anti-countermeasure targeting.`;
-				if (S.AA >= 5) lock=`Installed multispectrum countermeasures protect against all types of missile locks.`;
-				if (S.AA >= 6) group=`A respectable number of attack VTOL protect your arcology, split into a few squadrons`;
-				if (S.AA >= 7) support=` attack ground targets`; W2=`; rocket pods, and air-to-air missiles,`;
-				if (S.AA >= 8) stealth=`The old skin has been replaced with a radar-absorbent material, making the aircraft difficult to pick up on radar.`;
-				if (S.AA >= 9) scramble=`The VTOLs can scramble to react to any threat in under three minutes.`;
-				if (S.AA >= 10) PAI=`A piloting AI has been installed, allowing the VTOLs to perform impossible maneuvers that cannot be done by a human pilot. This removes the need for a human in the aircraft altogether.`;
+			if (S.AA >= 1) { r += `<br>&nbsp;&nbsp;''Assault:''`;
+				if (S.AA >= 2) W1 = `armed`; W2 = ` and air-to-air missiles,`; W3 = `a combination that can defend the arcology from enemy aircraft, as well as`; support = ` support ground troops`;
+				if (S.AA >= 3) engines = `The engines have been tuned, allowing faster flight with greater acceleration.`;
+				if (S.AA >= 4) TAI = `An advanced targeting AI has been installed to handle all control of weapons, allowing much more efficient use of ammunition and anti-countermeasure targeting.`;
+				if (S.AA >= 5) lock = `Installed multispectrum countermeasures protect against all types of missile locks.`;
+				if (S.AA >= 6) group = `A respectable number of attack VTOL protect your arcology, split into a few squadrons`;
+				if (S.AA >= 7) support = ` attack ground targets`; W2 = `; rocket pods, and air-to-air missiles,`;
+				if (S.AA >= 8) stealth = `The old skin has been replaced with a radar-absorbent material, making the aircraft difficult to pick up on radar.`;
+				if (S.AA >= 9) scramble = `The VTOLs can scramble to react to any threat in under three minutes.`;
+				if (S.AA >= 10) PAI = `A piloting AI has been installed, allowing the VTOLs to perform impossible maneuvers that cannot be done by a human pilot. This removes the need for a human in the aircraft altogether.`;
 				return `${r} ${group}. Several of the landing pads around ${V.arcologies[0].name} host groups of four fighters, ready to defend the arcology. ${scramble} The attack VTOL are currently ${W1} with a Gatling cannon${W2} ${W3}${support}. ${TAI} ${PAI} ${engines} ${lock} ${stealth}`;
 			} break;
 		case 'TA':
-			let Num=`number`, type=`tiltrotor`, capacity=`small platoon or 15`, engines0=``, engines01=``, Radar=``, Armor=``, landing=``, miniguns=``, counter=``;
-			if (S.TA >= 1) {r += `<br>&nbsp;&nbsp;''Transport:''`;
-				if (S.TA >= 2) engines0=`The tiltrotor engines have been replaced with a more powerful engine, allowing faster travel times.`;
-				if (S.TA >= 3) counter=`Multispectrum countermeasures have been added to protect against guided missiles.`;
-				if (S.TA >= 4) miniguns=`Mounted miniguns have been installed to cover soldiers disembarking in dangerous areas.`;
-				if (S.TA >= 5) Num=`large number`;
-				if (S.TA >= 6) landing=`The landing equipment has been overhauled, protecting personnel and cargo in the event of a hard landing or crash.`;
-				if (S.TA >= 7) Armor=`Armor has been added to protect passengers from small arms fire from below.`;
-				if (S.TA >= 8) capacity=`large platoon or 20`; engines01=`Further tweaks to the engine allow for greater lifting capacity.`;
-				if (S.TA >= 9) Radar=`Radar-absorbent materials have replaced the old skin, making it difficult to pick up the VTOL on radar.`;
-				if (S.TA >= 10) type=`tiltjet`; engines01=``; engines0=`The tiltrotors have been replaced with tiltjets, allowing for much greater airspeed and acceleration.`;
+			if (S.TA >= 1) { r += `<br>&nbsp;&nbsp;''Transport:''`;
+				if (S.TA >= 2) engines0 = `The tiltrotor engines have been replaced with a more powerful engine, allowing faster travel times.`;
+				if (S.TA >= 3) counter = `Multispectrum countermeasures have been added to protect against guided missiles.`;
+				if (S.TA >= 4) miniguns = `Mounted miniguns have been installed to cover soldiers disembarking in dangerous areas.`;
+				if (S.TA >= 5) Num = `large number`;
+				if (S.TA >= 6) landing = `The landing equipment has been overhauled, protecting personnel and cargo in the event of a hard landing or crash.`;
+				if (S.TA >= 7) Armor = `Armor has been added to protect passengers from small arms fire from below.`;
+				if (S.TA >= 8) capacity = `large platoon or 20`; engines01 = `Further tweaks to the engine allow for greater lifting capacity.`;
+				if (S.TA >= 9) Radar = `Radar-absorbent materials have replaced the old skin, making it difficult to pick up the VTOL on radar.`;
+				if (S.TA >= 10) type = `tiltjet`; engines01 = ``; engines0 = `The tiltrotors have been replaced with tiltjets, allowing for much greater airspeed and acceleration.`;
 				return `${r} A ${Num} of transport ${type} VTOL have been recommissioned for use by ${V.SF.Lower}. The VTOLs are resting on large pads near the base to load either a ${capacity} tons of material. ${engines0} ${engines01} ${Armor} ${landing} ${counter} ${Radar} ${miniguns}`;
 			} break;
 		case 'SP':
-			let engine20=`ramjet engines in the atmosphere that can reach Mach 10`, b5=`has been purchased from an insolvent Old World nation. It `, shield=``, camera=``, efficiency=``, camera2=``, drag=``, crew=``, engine2=``, skin=``;
-			if (S.SpacePlane >= 1) {r += `<br>&nbsp;''Spaceplane:''`;
-				if (S.SpacePlane >= 2) b5=``; shield=`The current heat shielding has been upgraded, reducing the likelihood of heat damage during reentry.`;
-				if (S.SpacePlane >= 3) engine2=` and liquid rocket engines in orbit that can reach an equivalent Mach 18`;
-				if (S.SpacePlane >= 4) camera=`A state-of-the-art camera has been installed in the underbelly that takes incredibly high resolution photos, but requires the frictionless environment of space to focus.`;
-				if (S.SpacePlane >= 5) efficiency=`Tweaks to the engines have increased fuel efficiency to the point where midflight refueling is no longer necessary.`;
-				if (S.SpacePlane >= 6) camera2=`The camera sensor is capable of taking IR shots.`;
-				if (S.SpacePlane >= 7) drag=`Miraculous advances in aerodynamics and materials allow frictionless flight, even while in the atmosphere.`;
-				if (S.SpacePlane >= 8) crew=`Increased the crew comfort and life support systems to increase operational time.`;
-				if (S.SpacePlane >= 9) skin=`Replaced the underbelly skin with a chameleon kit, matching the color to the sky above it.`;
-				if (S.SpacePlane >= 10) engine20=`experimental scramjet engines in the atmosphere that can reach Mach 15`; engine2=` and liquid rocket engines in orbit that can reach an equivalent Mach 25`;
+			if (S.SpacePlane >= 1) { r += `<br>&nbsp;''Spaceplane:''`;
+				if (S.SpacePlane >= 2) b5 = ``; shield = `The current heat shielding has been upgraded, reducing the likelihood of heat damage during reentry.`;
+				if (S.SpacePlane >= 3) engine2 = ` and liquid rocket engines in orbit that can reach an equivalent Mach 18`;
+				if (S.SpacePlane >= 4) camera = `A state-of-the-art camera has been installed in the underbelly that takes incredibly high resolution photos, but requires the frictionless environment of space to focus.`;
+				if (S.SpacePlane >= 5) efficiency = `Tweaks to the engines have increased fuel efficiency to the point where midflight refueling is no longer necessary.`;
+				if (S.SpacePlane >= 6) camera2 = `The camera sensor is capable of taking IR shots.`;
+				if (S.SpacePlane >= 7) drag = `Miraculous advances in aerodynamics and materials allow frictionless flight, even while in the atmosphere.`;
+				if (S.SpacePlane >= 8) crew = `Increased the crew comfort and life support systems to increase operational time.`;
+				if (S.SpacePlane >= 9) skin = `Replaced the underbelly skin with a chameleon kit, matching the color to the sky above it.`;
+				if (S.SpacePlane >= 10) engine20 = `experimental scramjet engines in the atmosphere that can reach Mach 15`; engine2 = ` and liquid rocket engines in orbit that can reach an equivalent Mach 25`;
 				return `${r} A prototype spaceplane ${b5} rests in the hangar, its black fuselage gleaming. The craft is powered by ${engine20}${engine2}. ${efficiency} ${shield} ${camera} ${camera2} ${drag} ${crew} ${skin}`;
 			} break;
 		case 'GunS':
-			let a=`has been recommissioned for use by ${V.SF.Lower}. Currently, it `, b4=``, c2=``, d=``, e=`Miniguns and Gatling cannons line`, f=`, though the distance to ground targets renders the smaller calibers somewhat less useful`, g=``, h=``, i=``, j=``, k=``;
-			if(S.GunS >= 1) {r += `<br>&nbsp;''Gunship:''`;
-				if (S.GunS >= 2) b4=`Infrared sensors have been added for the gunners to better pick targets.`; a=``;
-				if (S.GunS >= 3) c2=`The underside of the aircraft has been better armored against small-arms fire`; h=`.`;
-				if (S.GunS >= 4) d=`Larger fuel tanks have been installed in the wings and fuselage, allowing the gunship to provide aerial support for longer periods before refueling.`;
-				if (S.GunS >= 5) e=`25 mm Gatling cannons`; f=`; allowing the gunship to eliminate infantry`; j=` and light vehicles from above`; k=` and a 40 mm autocannon are mounted on`;
-				if (S.GunS >= 6) g=`The engines have been replaced, allowing both faster travel to a target, and slower travel around a target.`;
-				if (S.GunS >= 7) h=`; and multi-spectrum countermeasures have been installed to protect against guided missiles.`;
-				if (S.GunS >= 8) b4=`Upgraded multi-spectrum sensors can clearly depict targets even with IR shielding.`;
-				if (S.GunS >= 9) i=`The ammunition storage has been increased, only slightly depriving loaders of a place to sit.`;
-				if (S.GunS >= 10) j=`; both light and heavy vehicles, and most enemy cover from above`; k=`; a 40 mm autocannon, and a 105 mm howitzer are mounted on`;
-				return `${r} A large gunship ${a} is being refueled in the hangar. ${e}${k} the port side of the fuselage${f}${j}. ${b4} ${i} ${g} ${c2}${h} ${d}`;
+			if(S.GunS >= 1) { r += `<br>&nbsp;''Gunship:''`;
+				if (S.GunS >= 2) b4 = `Infrared sensors have been added for the gunners to better pick targets.`; activate2 = ``;
+				if (S.GunS >= 3) c2 = `The underside of the aircraft has been better armored against small-arms fire`; countermeasures = `.`;
+				if (S.GunS >= 4) fuel = `Larger fuel tanks have been installed in the wings and fuselage, allowing the gunship to provide aerial support for longer periods before refueling.`;
+				if (S.GunS >= 5) barrels = `25 mm Gatling cannons`; distance = `; allowing the gunship to eliminate infantry`; DFA = ` and light vehicles from above`; autocannon = ` and a 40 mm autocannon are mounted on`;
+				if (S.GunS >= 6) GS_Speed = `The engines have been replaced, allowing both faster travel to a target, and slower travel around a target.`;
+				if (S.GunS >= 7) countermeasures = `; and multi-spectrum countermeasures have been installed to protect against guided missiles.`;
+				if (S.GunS >= 8) b4 = `Upgraded multi-spectrum sensors can clearly depict targets even with IR shielding.`;
+				if (S.GunS >= 9) ammunition = `The ammunition storage has been increased, only slightly depriving loaders of a place to sit.`;
+				if (S.GunS >= 10) DFA = `; both light and heavy vehicles, and most enemy cover from above`; autocannon = `; a 40 mm autocannon, and a 105 mm howitzer are mounted on`;
+				return `${r} A large gunship ${activate2} is being refueled in the hangar. ${barrels}${autocannon} the port side of the fuselage${distance}${DFA}. ${b4} ${ammunition} ${GS_Speed} ${c2}${countermeasures} ${fuel}`;
 			} break;
 		case 'sat':
-			let loc1=`An unused science satellite has been purchased from an Old World nation. While currently useless, it holds potential to be a powerful tool.`, gyro=``, telemetry=``, thrusters=``, solar=``, surviv=``, laser1=``, heat=``, reactor=``, lens=``, kin=``;
-			if (S.Satellite.lv >= 1) {r += `<br>&nbsp;''Satellite:''`;
+			if (S.Satellite.lv >= 1) { r += `<br>&nbsp;''Satellite:''`;
 				if (S.Satellite.lv >= 2)
-					if (V.SF.Squad.Satellite.InOrbit < 1) loc1=`The satellite is being worked on in the Launch Bay.`; else loc1=`The satellite is in geosynchronous orbit, far above the arcology.`; gyro=`A suite of sensors have been installed to ensure the satellite can detect attitude and orbital altitude.`;
-				if (S.Satellite.lv >= 3) telemetry=`Telemetry systems have been installed to communicate with the satellite in orbit, with strong encryption measures.`;
-				if (S.Satellite.lv >= 4) thrusters=`Thrusters have been installed to control satellite attitude and orbit.`;
-				if (S.Satellite.lv >= 5) solar=`A massive folding solar panel array, combined with the latest in battery technology allow the satellite to store an enormous amount of energy relatively quickly.`; surviv=`Enough of the satellite has been finished that it can expect to survive for a significant period of time in space.`;
-				if (S.Satellite.lv >= 6) laser1=`A laser cannon has been mounted facing the earth, capable of cutting through steel in seconds`; heat=` while generating a large amount of heat.`;
-				if (S.Satellite.lv >= 7) heat=`. The installed heatsink allows the laser cannon to fire more frequently without damaging the satellite.`;
-				if (S.Satellite.lv >= 8) reactor=`A small, efficient nuclear reactor has been installed to continue generating energy while in the Earth's shadow.`;
-				if (S.Satellite.lv >= 9) lens=`A higher quality and adjustable lens has been installed on the laser, allowing scalpel precision on armor or wide-area blasts on unarmored targets.`;
-				if (S.Satellite.lv >= 10) kin=`A magazine of directable tungsten rods have been mounted to the exterior of the satellite, allowing for kinetic bombardment roughly equal to a series of nuclear blasts.`;
-			 return `${r} ${loc1} ${gyro} ${thrusters} ${telemetry} ${solar} ${reactor} ${surviv} ${laser1}${heat} ${lens} ${kin}`;
+					if (V.SF.Squad.Satellite.InOrbit < 1) loc1 = `The satellite is being worked on in the Launch Bay.`; else loc1 = `The satellite is in geosynchronous orbit, far above the arcology.`; gyro = `A suite of sensors have been installed to ensure the satellite can detect attitude and orbital altitude.`;
+				if (S.Satellite.lv >= 3) telemetry = `Telemetry systems have been installed to communicate with the satellite in orbit, with strong encryption measures.`;
+				if (S.Satellite.lv >= 4) thrusters = `Thrusters have been installed to control satellite attitude and orbit.`;
+				if (S.Satellite.lv >= 5) solar = `A massive folding solar panel array, combined with the latest in battery technology allow the satellite to store an enormous amount of energy relatively quickly.`; surviv = `Enough of the satellite has been finished that it can expect to survive for a significant period of time in space.`;
+				if (S.Satellite.lv >= 6) laser1 = `A laser cannon has been mounted facing the earth, capable of cutting through steel in seconds`; heat = ` while generating a large amount of heat.`;
+				if (S.Satellite.lv >= 7) heat = `. The installed heatsink allows the laser cannon to fire more frequently without damaging the satellite.`;
+				if (S.Satellite.lv >= 8) reactor = `A small, efficient nuclear reactor has been installed to continue generating energy while in the Earth's shadow.`;
+				if (S.Satellite.lv >= 9) lens = `A higher quality and adjustable lens has been installed on the laser, allowing scalpel precision on armor or wide-area blasts on unarmored targets.`;
+				if (S.Satellite.lv >= 10) kin = `A magazine of directable tungsten rods have been mounted to the exterior of the satellite, allowing for kinetic bombardment roughly equal to a series of nuclear blasts.`;
+				return `${r} ${loc1} ${gyro} ${thrusters} ${telemetry} ${solar} ${reactor} ${surviv} ${laser1}${heat} ${lens} ${kin}`;
 			} break;
 		case 'GR':
-			let loc=`has been purchased from a crumbling Old World nation. It`, power=`Large batteries mounted in oversized shoulders power the robot for up to ten minutes of use, though they make for large targets.`, knife=`simply a 8.5 meter long knife, though additional weapons are under development.`, armor8=``, actuator=``, cannon1=``, heatsink=``, ammo2=``, missile=``;
-			if (S.GiantRobot >= 1) {r += `<br>&nbsp;''Giant Robot:''`;
-				if (S.GiantRobot >= 2) loc=``; armor8=`Armor plating has been mounted over the majority of the robot.`;
-				if (S.GiantRobot >= 3) power=`The robot is now powered by an umbilical cable system instead of bulky and short-lived batteries.`;
-				if (S.GiantRobot >= 4) knife=`a 25 meter plasma sword. The cutting edge uses plasma to melt and cut through targets, reducing the strain on the sword.`;
-				if (S.GiantRobot >= 5) actuator=`The limb actuators have been replaced with a faster and more powerful variant, granting the robot the same.`;
-				if (S.GiantRobot >= 6) cannon1=`A custom 45 mm Gatling cannon rifle has been developed for ranged use`; ammo2=`; though it lacks enough ammo storage for a main weapon.`;
-				if (S.GiantRobot >= 7) heatsink=`Large heatsinks have been installed out of the back to solve a massive overheating problem. These heatsinks resemble wings, and tend to glow red with heat when in heavy use.`;
-				if (S.GiantRobot >= 8) armor8=``; actuator=`Final actuator tweaks have allowed for the addition of exceptionally thick armor without any loss in speed or power.`;
-				if (S.GiantRobot >= 9) ammo2=`; with spare ammunition drums kept along the robot's waist.`;
-				if (S.GiantRobot >= 10) missile=`Missile pods have been mounted on the shoulders.`;
+			if (S.GiantRobot >= 1) { r += `<br>&nbsp;''Giant Robot:''`;
+				if (S.GiantRobot >= 2) loc = ``; armor8 = `Armor plating has been mounted over the majority of the robot.`;
+				if (S.GiantRobot >= 3) power = `The robot is now powered by an umbilical cable system instead of bulky and short-lived batteries.`;
+				if (S.GiantRobot >= 4) knife = `a 25 meter plasma sword. The cutting edge uses plasma to melt and cut through targets, reducing the strain on the sword.`;
+				if (S.GiantRobot >= 5) actuator = `The limb actuators have been replaced with a faster and more powerful variant, granting the robot the same.`;
+				if (S.GiantRobot >= 6) cannon1 = `A custom 45 mm Gatling cannon rifle has been developed for ranged use`; ammo2 = `; though it lacks enough ammo storage for a main weapon.`;
+				if (S.GiantRobot >= 7) heatsink = `Large heatsinks have been installed out of the back to solve a massive overheating problem. These heatsinks resemble wings, and tend to glow red with heat when in heavy use.`;
+				if (S.GiantRobot >= 8) armor8 = ``; actuator = `Final actuator tweaks have allowed for the addition of exceptionally thick armor without any loss in speed or power.`;
+				if (S.GiantRobot >= 9) ammo2 = `; with spare ammunition drums kept along the robot's waist.`;
+				if (S.GiantRobot >= 10) missile = `Missile pods have been mounted on the shoulders.`;
 				return `${r} A prototype giant robot ${loc} rests in a gantry along the side of the arcology. The robot is as tall as a medium-sized office building, focusing on speed over other factors. ${power} ${armor8} ${actuator} ${heatsink} The main armament is ${knife} ${cannon1}${ammo2} ${missile}`;
 			} break;
 		case 'ms':
-			let a4=`A cruise missile launch site has been constructed near the base of`, b2=`outdated, something quickly rigged together to give the launch site something to fire in the case of an attack`, c8=``, d1=``, e1=``, f1=``, g1=``, h1=``;
-			if (S.MissileSilo >= 1) {r += `<br>&nbsp;''Cruise Missile:''`;
-				if (S.MissileSilo >= 2) b2=`a modern missile`; c8=`; tipped with a conventional warhead`;
-				if (S.MissileSilo >= 3) d1=`The launch systems have been overhauled, allowing a launch within seconds of an attack order being given.`;
-				if (S.MissileSilo >= 4) e1=`The missile engines have been tweaked, giving them a greater range.`;
-				if (S.MissileSilo >= 5) f1=`A passive radar has been installed, allowing the missile to follow moving targets.`;
-				if (S.MissileSilo >= 6) a4=`Several cruise missile launch sites have been constructed around`;
-				if (S.MissileSilo >= 7) e1=`The engine has been replaced, giving the missiles greater range and supersonic speeds.`;
-				if (S.MissileSilo >= 8) g1=`The ability to pick new targets should the original be lost has been added.`;
-				if (S.MissileSilo >= 9) h1=`The missile now uses its remaining fuel to create a thermobaric explosion, massively increasing explosive power.`;
-				if (S.MissileSilo >= 10) c8=` that can be tipped with either a conventional or nuclear warhead`;
+			if (S.MissileSilo >= 1) { r += `<br>&nbsp;''Cruise Missile:''`;
+				if (S.MissileSilo >= 2) b2 = `a modern missile`; c8 = `; tipped with a conventional warhead`;
+				if (S.MissileSilo >= 3) d1 = `The launch systems have been overhauled, allowing a launch within seconds of an attack order being given.`;
+				if (S.MissileSilo >= 4) e1 = `The missile engines have been tweaked, giving them a greater range.`;
+				if (S.MissileSilo >= 5) f1 = `A passive radar has been installed, allowing the missile to follow moving targets.`;
+				if (S.MissileSilo >= 6) a4 = `Several cruise missile launch sites have been constructed around`;
+				if (S.MissileSilo >= 7) e1 = `The engine has been replaced, giving the missiles greater range and supersonic speeds.`;
+				if (S.MissileSilo >= 8) g1 = `The ability to pick new targets should the original be lost has been added.`;
+				if (S.MissileSilo >= 9) h1 = `The missile now uses its remaining fuel to create a thermobaric explosion, massively increasing explosive power.`;
+				if (S.MissileSilo >= 10) c8 = ` that can be tipped with either a conventional or nuclear warhead`;
 				return `${r} ${a4} the arcology. The current missile armament is ${b2}${c8}. ${d1} ${e1} ${f1} ${g1} ${h1}`;
 			} break;
 		case 'AC':
-			let recom1=`has been recommissioned from the Old World for ${V.SF.Lower}. It`, jets=`Formerly mothballed strike jets`, loc2=``, radar=``, AAG=``, prop=``, torp=``, armor9=``, power1=``, scramble1=``;
-			if (S.AircraftCarrier >= 1) {r += `<br>&nbsp;''Aircraft Carrier:''`;
-				if (V.week % 6 === 0) loc2=`moored to the pier in the Naval Yard`; else loc2=`patrolling the waters near ${V.arcologies[0].name}`;
-				if (S.AircraftCarrier >= 2) radar=`The island's radar and comms have been improved.`; recom1=``;
-				if (S.AircraftCarrier >= 3) AAG=`The antiair guns have been updated to automatically track and predict enemy aircraft movement.`;
-				if (S.AircraftCarrier >= 4) jets=`Modern strike jets with state-of-the-art armaments`;
-				if (S.AircraftCarrier >= 5) prop=`The propellers have been redesigned, granting greater speed with less noise.`;
-				if (S.AircraftCarrier >= 6) torp=`An anti-torpedo system detects and destroys incoming torpedoes.`;
-				if (S.AircraftCarrier >= 7) armor9=`Additional armor has been added to the hull and deck.`;
-				if (S.AircraftCarrier >= 8) power1=`The power plant has been converted to provide nuclear power.`;
-				if (S.AircraftCarrier >= 9) scramble1=`The catapult has been converted to an electromagnetic launch system, halving the time it takes to scramble1 jets.`;
-				if (S.AircraftCarrier >= 10) jets=`Attack VTOL from the converted for carrier capability`;
+			if (S.AircraftCarrier >= 1) { r += `<br>&nbsp;''Aircraft Carrier:''`;
+				if (V.week % 6 === 0) loc2 = `moored to the pier in the Naval Yard`; else loc2 = `patrolling the waters near ${V.arcologies[0].name}`;
+				if (S.AircraftCarrier >= 2) radar = `The island's radar and comms have been improved.`; recom1 = ``;
+				if (S.AircraftCarrier >= 3) AAG = `The antiair guns have been updated to automatically track and predict enemy aircraft movement.`;
+				if (S.AircraftCarrier >= 4) jets = `Modern strike jets with state-of-the-art armaments`;
+				if (S.AircraftCarrier >= 5) prop = `The propellers have been redesigned, granting greater speed with less noise.`;
+				if (S.AircraftCarrier >= 6) torp = `An anti-torpedo system detects and destroys incoming torpedoes.`;
+				if (S.AircraftCarrier >= 7) armor9 = `Additional armor has been added to the hull and deck.`;
+				if (S.AircraftCarrier >= 8) power1 = `The power plant has been converted to provide nuclear power.`;
+				if (S.AircraftCarrier >= 9) scramble1 = `The catapult has been converted to an electromagnetic launch system, halving the time it takes to scramble1 jets.`;
+				if (S.AircraftCarrier >= 10) jets = `Attack VTOL from the converted for carrier capability`;
 				return `${r} An aircraft carrier ${recom1} is ${loc2}. ${jets} serve as its airpower. ${scramble1} ${power1} ${radar} ${AAG} ${torp} ${prop} ${armor9}`;
 			} break;
 		case 'Sub':
-			let recom=`has been recommissioned from the old world, and`, reactor0=`Because diesel engines provide power and breathing oxygen is kept in pressurized canisters, the sub must frequently surface.`, reactor1=``, cal=``, hull=``, tubes=``, torpedoes=``, sonar=``, control=``, missiles=``;
-			if (S.Sub >= 1) {r += `<br>&nbsp;''Submarine:''`;
-				if (S.Sub >= 2) recom=``; reactor0=`A nuclear reactor provides power`; reactor1=`; but because oxygen is still kept in pressurized canisters the sub must frequently surface to replenish its oxygen stocks.`;
-				if (S.Sub >= 3) reactor1=` and an oxygen generator pulls Oâ‚‚ from the surrounding seawater, allowing the submarine to remain underwater for months if necessary.`;
-				if (S.Sub >= 4) cal=`Calibration of the propulsion systems has reduced the telltale hum of a moving sub to a whisper.`;
-				if (S.Sub >= 5) hull=`The outer hull has been redesigned for hydrodynamics and sonar absorption.`;
-				if (S.Sub >= 6) tubes=`The torpedo tubes have been redesigned for faster loading speeds`; torpedoes=`.`;
-				if (S.Sub >= 7) sonar=`The passive sonar has been finely tuned to detect mechanical noises miles away.`;
-				if (S.Sub >= 8) control=`The control room computers have been upgraded to automate many conn duties.`;
-				if (S.Sub >= 9) torpedoes=`and launch more agile torpedoes.`;
-				if (S.Sub >= 10) missiles=`The submarine has been outfitted with several cruise missiles to attack land or sea-based targets.`;
+			if (S.Sub >= 1) { r += `<br>&nbsp;''Submarine:''`;
+				if (S.Sub >= 2) recom = ``; reactor0 = `A nuclear reactor provides power`; reactor1 = `; but because oxygen is still kept in pressurized canisters the sub must frequently surface to replenish its oxygen stocks.`;
+				if (S.Sub >= 3) reactor1 = ` and an oxygen generator pulls Oâ‚‚ from the surrounding seawater, allowing the submarine to remain underwater for months if necessary.`;
+				if (S.Sub >= 4) cal = `Calibration of the propulsion systems has reduced the telltale hum of a moving sub to a whisper.`;
+				if (S.Sub >= 5) hull = `The outer hull has been redesigned for hydrodynamics and sonar absorption.`;
+				if (S.Sub >= 6) tubes = `The torpedo tubes have been redesigned for faster loading speeds`; torpedoes = `.`;
+				if (S.Sub >= 7) sonar = `The passive sonar has been finely tuned to detect mechanical noises miles away.`;
+				if (S.Sub >= 8) control = `The control room computers have been upgraded to automate many conn duties.`;
+				if (S.Sub >= 9) torpedoes = `and launch more agile torpedoes.`;
+				if (S.Sub >= 10) missiles = `The submarine has been outfitted with several cruise missiles to attack land or sea-based targets.`;
 				return `${r} An attack submarine ${recom} is moored to the pier of the Naval Yard. ${reactor0}${reactor1} ${cal} ${hull} ${tubes}${torpedoes} ${sonar} ${control} ${missiles}`;
 			} break;
 		case 'HAT':
-			let recom2=`; has been recommissioned for use by ${V.SF.Lower}. It`, tons=`200`, skirt=``, guns=``, guns2=``, fans=``, speed=``, turbines=``, armor10=``, ramps=``, HATframe=``, loadout=``;
 			if (S.HAT >= 1) {r += `<br>&nbsp;''Amphibious Transport:''`;
-				if (S.HAT >= 2) skirt=`The skirt has been upgraded to increase durability and improve cushion when traveling over uneven terrain and waves.`; recom2=`;`;
-				if (S.HAT >= 3) guns=`A minigun`; guns2=`has been mounted on the front corners of the craft to defend against attackers.`;
-				if (S.HAT >= 4) fans=`The turbines powering the rear fans`; speed=`acceleration and speed.`; turbines=`have been replaced with a more powerful version, allowing greater`;
-				if (S.HAT >= 5) armor10=`The armor protecting its cargo has been increased.`;
-				if (S.HAT >= 6) tons=`300`; fans=`The turbines powering the rear fans and impeller`; speed=`acceleration, speed, and carrying capacity.`;
-				if (S.HAT >= 7) guns=`A minigun and grenade launcher`;
-				if (S.HAT >= 8) ramps=`The loading ramps have been improved, allowing for faster unloading.`;
-				if (S.HAT >= 9) HATframe=`The frame has been widened and reinforced, allowing for more space on the deck.`;
-				if (S.HAT >= 10) loadout=`An experimental loadout sacrifices all carrying capacity to instead act as a floating gun platform by mounting several rotary autocannons the deck, should the need arise.`;
+				if (S.HAT >= 2) skirt = `The skirt has been upgraded to increase durability and improve cushion when traveling over uneven terrain and waves.`; recom2 = `;`;
+				if (S.HAT >= 3) guns = `A minigun`; guns2 = `has been mounted on the front corners of the craft to defend against attackers.`;
+				if (S.HAT >= 4) fans = `The turbines powering the rear fans`; speed = `acceleration and speed.`; turbines = `have been replaced with a more powerful version, allowing greater`;
+				if (S.HAT >= 5) armor10 = `The armor protecting its cargo has been increased.`;
+				if (S.HAT >= 6) tons = `300`; fans = `The turbines powering the rear fans and impeller`; speed = `acceleration, speed, and carrying capacity.`;
+				if (S.HAT >= 7) guns = `A minigun and grenade launcher`;
+				if (S.HAT >= 8) ramps = `The loading ramps have been improved, allowing for faster unloading.`;
+				if (S.HAT >= 9) HATframe = `The frame has been widened and reinforced, allowing for more space on the deck.`;
+				if (S.HAT >= 10) loadout = `An experimental loadout sacrifices all carrying capacity to instead act as a floating gun platform by mounting several rotary autocannons the deck, should the need arise.`;
 				return `${r} An air cushion transport vehicle, or hovercraft ${recom2} is parked on the pier of the Naval Yard, ready to ferry ${tons} tons of soldiers and vehicles. ${guns} ${guns2} ${fans} ${turbines} ${speed} ${skirt} ${armor10} ${ramps} ${HATframe} ${loadout}`;
 			} break;
 	}
@@ -793,19 +961,19 @@ window.UnitText = function(input) {
 };
 
 /*window.FSIntegrationMenu = function() {
-	const V=State.variables;
-	const UpgradeOptions=['Slaves','FoodsAndMedia','CommonArea','Barracks', 'SlaveProcessingCages','CommandCenter','Armory','DrugLab','Garage','Hangar', 'DroneBay','PersonalItems','VehicleUpgrades','CommonAreaVendors', 'RoleplayingManadated','ColonelCompilance','ColonelGift'];
-	const FS_OPTIONS=['Repopulation','Eugenics','Gender radicalism','Gender traditionalism','Paternalism','Degradationism','Body Purism', 'Transformation Fetishism','Youth Preferentialism','Maturity Preferentialism','Slimness Enthusiasm','Asset Expansionism','Slave Pastoralism','Physical Idealism','Hedonistic Decadence','Chattel Religionism','Roman Revivalism','Aztec Revivalism','Egyptian Revivalism','Edo Revivalism','Arabian Revivalism','Chinese Revivalism','Multiculturalism'];
-	var text=``;
+	const V = State.variables;
+	const UpgradeOptions = ['Slaves','FoodsAndMedia','CommonArea','Barracks', 'SlaveProcessingCages','CommandCenter','Armory','DrugLab','Garage','Hangar', 'DroneBay','PersonalItems','VehicleUpgrades','CommonAreaVendors', 'RoleplayingManadated','ColonelCompilance','ColonelGift'];
+	const FS_OPTIONS = ['Repopulation','Eugenics','Gender radicalism','Gender traditionalism','Paternalism','Degradationism','Body Purism', 'Transformation Fetishism','Youth Preferentialism','Maturity Preferentialism','Slimness Enthusiasm','Asset Expansionism','Slave Pastoralism','Physical Idealism','Hedonistic Decadence','Chattel Religionism','Roman Revivalism','Aztec Revivalism','Egyptian Revivalism','Edo Revivalism','Arabian Revivalism','Chinese Revivalism','Multiculturalism'];
+	var text = ``;
 	if (V.SF.FS === undefined) {
 		text += `<br><br>`;
 		//text += ``;
 		V.SF.FS={Acceptance:{'FS':[],'Percent':[]}, Upgrade:0, Annoyance:0, Options:{ 'Slaves':[], 'FoodsAndMedia':[], 'CommonArea':[], 'Barracks':[], 'SlaveProcessingCages':[], 'CommandCenter':[], 'Armory':[], 'DrugLab':[], 'Garage':[], 'Hangar':[], 'DroneBay':[], 'PersonalItems':[], 'VehicleUpgrades':[], 'CommonAreaVendors':[], 'RoleplayingManadated':[], 'ColonelCompilance':[], 'ColonelGift':[] }};
-		V.SF.Colonel.Talk=1;
+		V.SF.Colonel.Talk = 1;
 	} else {
 		text += `You walk past The Colonel and move towards the common area to meet with an exclusive group of her very influential officers that are currently relaxing at their favorite table. These men and women are known for their competence, popularity, and authority within in their respective divisions of the ${V.SF.Lower}, they are hard to replace, and they are always looking to earn more coin; they are the perfect weak link for trickling your Future Society influences down into the Firebase. As the officers make room at their table for you to sit and join them for discussion, you spot The Colonel staring at you from afar, and she does not look happy with you. As you are her employer, she cannot stop you from speaking with her soldiers or moving around as you please, but she can tell that you are up to no good: <br><br>`;
 		const MEMU_OPTION = function(VisableName,ArraryName,Cost) {
-			var FinalVisableName=VisableName;
+			var FinalVisableName = VisableName;
 			if (ArraryName === 'ColonelGift') {
 				switch(POS) {
 					case 'Repopulation': FinalVisableName += ` Repopulationist`; break;
@@ -859,7 +1027,7 @@ window.UnitText = function(input) {
 				V.SF.FS.Annoyance -= 15;
 			}
 			V.Cash -= cost;
-			V.SF.FS.Upgrade=1;
+			V.SF.FS.Upgrade = 1;
 			<</link>> //costs <span class='yellowgreen'>${cashFormat($Cost)}</span>, `;
 			if (ArraryName !== 'ColonelGift') { text += `increases`;
 				} else { text += `reduces`; } text += ` The Colonel's annoyance by 15%`;
@@ -868,9 +1036,9 @@ window.UnitText = function(input) {
 			}
 			text += `.`;
 		}
-		const FSlist=FS_OPTIONS;
+		const FSlist = FS_OPTIONS;
 		for(let i = 0;i<FSlist.length;i++) {
-			let FSPOS=FSlist[i];
+			let FSPOS = FSlist[i];
 			if (i > 0) text += `<br>`;
 			switch(FSPOS) {
 				case 'Repopulation': text += `Repopulation Efforts: focus on mass breeding in order to repopulate the future world.`; break;
@@ -895,13 +1063,13 @@ window.UnitText = function(input) {
 				case 'Edo Revivalism': text += `Edo Revivalism: a vision of Edo Japan.`; break;
 				case 'Arabian Revivalism': text += `Arabian Revivalism: a vision of the Sultanate of old.`; break;
 				case 'Chinese Revivalism': text += `Chinese Revivalism: a vision of ancient China.`; break;
-				case 'Multiculturalism': text +=`Multiculturalism: a commitment to allow your arcology's citizens cultural freedom.`; break;
+				case 'Multiculturalism': text + = `Multiculturalism: a commitment to allow your arcology's citizens cultural freedom.`; break;
 			}
 			text += `\n&nbsp;Smuggle in FS-optimized : `;
-			const Optionslist=UpgradeOptions;
+			const Optionslist = UpgradeOptions;
 			for (let i = 0;i<Optionslist.length;i++) {
-				var OptPOS=Optionslist[i];
-				var title=``;
+				var OptPOS = Optionslist[i];
+				var title = ``;
 				switch(OptPOS) {
 					var cost=200000;
 					case 'FoodsAndMedia': title='Common area decorations'; break;
@@ -918,7 +1086,7 @@ window.UnitText = function(input) {
 					case 'VehicleUpgrades': title='Vehicle Upgrade'; cost=300000; break;
 					case 'CommonAreaVendors': title='Firebase Vendors'; cost=300000; break;
 					case 'RoleplayingManadated': title='Mandate FS-Roleplaying'; cost=500000; break;
-					case 'ColonelCompilance': title='colonel compliance'; cost=1000000; break;
+					case 'ColonelCompilance': title='colonel compliance'; cost = 1000000; break;
 				}
 				if (![FSPOS].includes(V.SF.Acceptance.FS)) {
 					MEMU_OPTION('Slaves','Slaves',cost), text += ` `;
diff --git a/src/SpecialForce/Upgrades.tw b/src/SpecialForce/Upgrades.tw
index f2485c413cb16de0e4fbd1927edb6f1dcca4e209..2d7ed05ea011ca9e5aa62cbbf38e50a8634f66c3 100644
--- a/src/SpecialForce/Upgrades.tw
+++ b/src/SpecialForce/Upgrades.tw
@@ -11,7 +11,7 @@
 		<<if $SF.Squad.Firebase < 5||_T1 && $SF.Squad.Firebase < _FU>> <br>
 			<<set _cF = SFUpgradeCost(100000,$SF.Squad.Firebase)>>
 			<<if $cash >= _cF>>
-				[[Upgrade Firebase|Firebase][$SF.Upgrade = 1, $SF.Squad.Firebase++, cashX(forceNeg(_cF), "specialForces")]]
+				[[Upgrade Firebase|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.Firebase++, cashX(forceNeg(_cF), "specialForces")]]
 			<<else>>//Cannot afford to upgrade the Firebase.//<</if>>
 			//Costs @@.red;<<print cashFormat(_cF)>>@@// <span style="float:right;"> <<print progress($SF.Squad.Firebase)>> </span><br>
 		<<elseif $SF.Squad.Firebase === _FU>> <br>//The Firebase has been fully upgraded.//<br><</if>>
@@ -19,7 +19,7 @@
 		<<if $SF.Squad.Armoury < 5||_T1 && $SF.Squad.Armoury < _AU>> <br>
 			<<set _cA = SFUpgradeCost(40000,$SF.Squad.Armoury)>>
 			<<if $cash >= _cA>>
-				[[Upgrade Armory|Firebase][$SF.Upgrade = 1, $SF.Squad.Armoury++, cashX(forceNeg(_cA), "specialForces")]]
+				[[Upgrade Armory|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.Armoury++, cashX(forceNeg(_cA), "specialForces")]]
 			<<else>>//Cannot afford to upgrade the Armory.//<</if>>
 			//Costs @@.red;<<print cashFormat(_cA)>>@@// <span style="float:right;"> <<print progress($SF.Squad.Armoury)>> </span><br>
 		<<elseif $SF.Squad.Armoury === _AU>> //The Armory has been fully upgraded.//<br><</if>>
@@ -27,7 +27,7 @@
 		<<if $SF.Squad.Drugs < 5||_T1 && $SF.Squad.Drugs < _DrugsU>> <br>
 			<<set _cDrugs = SFUpgradeCost(40000,$SF.Squad.Drugs)>>
 			<<if $cash >= _cDrugs>>
-				[[Upgrade Drug Lab|Firebase][$SF.Upgrade = 1, $SF.Squad.Drugs++, cashX(forceNeg(_cDrugs), "specialForces")]]
+				[[Upgrade Drug Lab|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.Drugs++, cashX(forceNeg(_cDrugs), "specialForces")]]
 			<<else>>//Cannot afford to upgrade the Drug Lab.//<</if>>
 			//Costs @@.red;<<print cashFormat(_cDrugs)>>@@// <span style="float:right;"> <<print progress($SF.Squad.Drugs)>> </span><br>
 		<<elseif $SF.Squad.Drugs === _DrugsU>> //The Drug Lab has been fully upgraded.//<br><</if>>
@@ -35,7 +35,7 @@
 		<<if $SF.Squad.Firebase >= 2 && ($SF.Squad.Drones < 5 ||_T1 && $SF.Squad.Drones < _DU)>> <br>
 			<<set _cDrones = SFUpgradeCost(45000,$SF.Squad.Drones)>>
 			<<if $cash >= _cDrones>>
-				[[Upgrade Drone Bay|Firebase][$SF.Upgrade = 1, $SF.Squad.Drones++, cashX(forceNeg(_cDrones), "specialForces")]]
+				[[Upgrade Drone Bay|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.Drones++, cashX(forceNeg(_cDrones), "specialForces")]]
 			<<else>>//Cannot afford to upgrade the Drone Bay.//<</if>>
 			//Costs @@.red;<<print cashFormat(_cDrones)>>@@// <span style="float:right;"> <<print progress($SF.Squad.Drones)>> </span><br><br>
 		<<elseif $SF.Squad.Drones === _DU>> //The Drone Bay has been fully upgraded.//<br><</if>>
@@ -44,7 +44,7 @@
 			<div style="margin-left:2em"><<if ($SF.Squad.AV < 5||_T1 && $SF.Squad.AV < _AVU)>>
 				<<set _cAV = SFUpgradeCost(60000,$SF.Squad.AV)>>
 				<<if $cash >= _cAV>>
-					[[Upgrade Attack Vehicle Fleet|Firebase][$SF.Upgrade = 1, $SF.Squad.AV++, cashX(forceNeg(_cAV), "specialForces")]]
+					[[Upgrade Attack Vehicle Fleet|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.AV++, cashX(forceNeg(_cAV), "specialForces")]]
 				<<else>>//Cannot afford to upgrade the Attack Vehicle Fleet.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cAV)>>@@// <span style="float:right;"><<print progress($SF.Squad.AV)>></span>
 			<<elseif $SF.Squad.AV === _AVU>> //The Attack Vehicle Fleet has been fully upgraded.//<br><</if>>
@@ -53,7 +53,7 @@
 			<div style="margin-left:2em"><<if ($SF.Squad.TV < 5||_T1 && $SF.Squad.TV < _TVU)>>
 				<<set _cTV = SFUpgradeCost(60000,$SF.Squad.TV)>>
 				<<if $cash >= _cTV>>
-					[[Upgrade Transport Vehicle Fleet|Firebase][$SF.Upgrade = 1, $SF.Squad.TV++, cashX(forceNeg(_cTV), "specialForces")]]
+					[[Upgrade Transport Vehicle Fleet|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.TV++, cashX(forceNeg(_cTV), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Transport Vehicle Fleet.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cTV)>>@@// <span style="float:right;"> <<print progress($SF.Squad.TV)>> </span>
 			<<elseif $SF.Squad.TV === _TVU>> //The Transport Vehicle Fleet has been fully upgraded.//<br><</if>>
@@ -62,7 +62,7 @@
 			<div style="margin-left:2em"><<if _T1 && $SF.Squad.PGT < _PGTU>>
 				<<set _cPGT = SFUpgradeCost(735000,$SF.Squad.PGT)>>
 				<<if $cash >= _cPGT>>
-					[[Upgrade Prototype Goliath tank|Firebase][$SF.Upgrade = 1, $SF.Squad.PGT++, cashX(forceNeg(_cPGT), "specialForces")]]
+					[[Upgrade Prototype Goliath tank|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.PGT++, cashX(forceNeg(_cPGT), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Prototype Goliath Tank.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cPGT)>>@@// <span style="float:right;"> <<print progress($SF.Squad.PGT)>> </span>
 			<<elseif $SF.Squad.PGT === _PGTU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.PGT)>> </span>
@@ -72,7 +72,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.AA < 5||_T1 && $SF.Squad.AA < _AAU>>
 				<<set _cAA = SFUpgradeCost(70000,$SF.Squad.AA)>>
 				<<if $cash >= _cAA>>
-					[[Upgrade Attack Aircraft Fleet|Firebase][$SF.Upgrade = 1, $SF.Squad.AA++, cashX(forceNeg(_cAA), "specialForces")]]
+					[[Upgrade Attack Aircraft Fleet|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.AA++, cashX(forceNeg(_cAA), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Attack Aircraft Fleet.//<</if>>
 			//Costs @@.red;<<print cashFormat(_cAA)>>@@// <span style="float:right;"> <<print progress($SF.Squad.AA)>> </span>
 			<<elseif $SF.Squad.AA === _AAU>> //The Attack Aircraft Fleet has been fully upgraded.//<br><</if>>
@@ -81,7 +81,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.TA < 5||_T1 && $SF.Squad.TA < _TAU>>
 				<<set _cTA = SFUpgradeCost(70000,$SF.Squad.TA)>>
 				<<if $cash >= _cTA>>
-					[[Upgrade Transport Aircraft Fleet|Firebase][$SF.Upgrade = 1, $SF.Squad.TA++, cashX(forceNeg(_cTA), "specialForces")]]
+					[[Upgrade Transport Aircraft Fleet|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.TA++, cashX(forceNeg(_cTA), "specialForces")]]
 				<<else>>//Cannot afford to upgrade the Transport Aircraft Fleet.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cTA)>>@@// <span style="float:right;"> <<print progress($SF.Squad.TA)>> </span>
 			<<elseif $SF.Squad.TA === _TAU>> //The Transport Aircraft Fleet has been fully upgraded.//<br><</if>>
@@ -90,7 +90,7 @@
 			<div style="margin-left:2em"><<if _T1 && $SF.Squad.SpacePlane < _SPU>>
 				<<set _cSP = SFUpgradeCost(250000,$SF.Squad.SpacePlane)>>
 				<<if $cash >= _cSP>>
-					[[Upgrade Spaceplane|Firebase][$SF.Upgrade = 1, $SF.Squad.SpacePlane++, cashX(forceNeg(_cSP), "specialForces")]]
+					[[Upgrade Spaceplane|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.SpacePlane++, cashX(forceNeg(_cSP), "specialForces")]]
 				<<else>>//Cannot afford to upgrade the Spaceplane.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cSP)>>@@//<span style="float:right;"><<print progress($SF.Squad.SpacePlane)>> </span>
 			<<elseif $SF.Squad.SpacePlane === _SPU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.SpacePlane)>> </span>
@@ -99,7 +99,7 @@
 			<div style="margin-left:2em"><<if _T1 && $SF.Squad.GunS < _GunSU>>
 				<<set _cGunS = SFUpgradeCost(350000,$SF.Squad.GunS)>>
 				<<if $cash >= _cGunS>>
-					[[Upgrade Gunship|Firebase][$SF.Upgrade = 1, $SF.Squad.GunS++, cashX(forceNeg(_cGunS), "specialForces")]]
+					[[Upgrade Gunship|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.GunS++, cashX(forceNeg(_cGunS), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Gunship.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cGunS)>>@@//<span style="float:right;"> <<print progress($SF.Squad.GunS)>> </span>
 			<<elseif $SF.Squad.GunS === _GunSU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.GunS)>> </span>
@@ -109,7 +109,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.Satellite.lv < _SatU && $SF.Squad.Satellite.InOrbit < 1>>
 				<<set _cSat = SFUpgradeCost(525000,$SF.Squad.Satellite.lv)>>
 				<<if $cash >= _cSat>>
-					[[Upgrade Satellite|Firebase][$SF.Upgrade = 1, $SF.Squad.Satellite.lv++, cashX(forceNeg(_cSat), "specialForces")]]
+					[[Upgrade Satellite|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.Satellite.lv++, cashX(forceNeg(_cSat), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Satellite.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cSat)>>@@//<span style="float:right;"><<print progress($SF.Squad.Satellite.lv)>> </span>
 			<<elseif $SF.Squad.Satellite.lv === _SatU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.Satellite.lv)>> </span>
@@ -119,7 +119,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.GiantRobot < _GRU>>
 				<<set _cGR = SFUpgradeCost(550000,$SF.Squad.GiantRobot)>>
 				<<if $cash >= _cGR>>
-					[[Upgrade Giant Robot|Firebase][$SF.Upgrade = 1, $SF.Squad.GiantRobot++, cashX(forceNeg(_cGR), "specialForces")]]
+					[[Upgrade Giant Robot|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.GiantRobot++, cashX(forceNeg(_cGR), "specialForces")]]
 				<<else>>//Cannot afford to upgrade the Giant Robot.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cGR)>>@@//<span style="float:right;"><<print progress($SF.Squad.GiantRobot)>></span>
 			<<elseif $SF.Squad.GiantRobot === _GRU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.GiantRobot)>> </span>
@@ -128,7 +128,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.MissileSilo < _MSU>>
 				<<set _cMS = SFUpgradeCost(565000,$SF.Squad.MissileSilo)>>
 				<<if $cash >= _cMS>>
-					[[Upgrade Cruise Missile|Firebase][$SF.Upgrade = 1, $SF.Squad.MissileSilo++, cashX(forceNeg(_cMS), "specialForces")]]
+					[[Upgrade Cruise Missile|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.MissileSilo++, cashX(forceNeg(_cMS), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Cruise Missile.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cMS)>>@@//<span style="float:right;"><<print progress($SF.Squad.MissileSilo)>></span>
 			<<elseif $SF.Squad.MissileSilo === _MSU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.MissileSilo)>> </span>
@@ -138,7 +138,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.AircraftCarrier < _ACU>>
 				<<set _cAC = SFUpgradeCost(650000,$SF.Squad.AircraftCarrier)>>
 				<<if $cash >= _cAC>>
-					[[Upgrade Aircraft Carrier|Firebase][$SF.Upgrade = 1, $SF.Squad.AircraftCarrier++, cashX(forceNeg(_cAC), "specialForces")]]
+					[[Upgrade Aircraft Carrier|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.AircraftCarrier++, cashX(forceNeg(_cAC), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Aircraft Carrier.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cAC)>>@@//<span style="float:right;"> <<print progress($SF.Squad.AircraftCarrier)>> </span>
 			<<elseif $SF.Squad.AircraftCarrier === _ACU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.AircraftCarrier)>> </span>
@@ -147,7 +147,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.Sub < _SubU>>
 				<<set _cSub = SFUpgradeCost(700000,$SF.Squad.Sub)>>
 				<<if $cash >= _cSub>>
-					[[Upgrade Submarine|Firebase][$SF.Upgrade = 1, $SF.Squad.Sub++, cashX(forceNeg(_cSub), "specialForces")]]
+					[[Upgrade Submarine|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.Sub++, cashX(forceNeg(_cSub), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Submarine//<</if>>
 				//Costs @@.red;<<print cashFormat(_cSub)>>@@//<span style="float:right;"> <<print progress($SF.Squad.Sub)>> </span>
 			<<elseif $SF.Squad.Sub === _SubU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.Sub)>> </span>
@@ -156,7 +156,7 @@
 			<div style="margin-left:2em"><<if $SF.Squad.HAT < _HATU>>
 				<<set _cHAT = SFUpgradeCost(665000,$SF.Squad.HAT)>>
 				<<if $cash >= _cHAT>>
-					[[Upgrade Amphibious Transport|Firebase][$SF.Upgrade = 1, $SF.Squad.HAT++, cashX(forceNeg(_cHAT), "specialForces")]]
+					[[Upgrade Amphibious Transport|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Squad.HAT++, cashX(forceNeg(_cHAT), "specialForces")]]
 				<<else>>//Cannot afford to upgrade Amphibious Transport.//<</if>>
 				//Costs @@.red;<<print cashFormat(_cHAT)>>@@//<span style="float:right;"> <<print progress($SF.Squad.HAT)>> </span>
 			<<elseif $SF.Squad.HAT === _HATU && $PC.warfare < 75>>//Your warfare skill is not high enough unlock the next upgrade.//<span style="float:right;"> <<print progress($SF.Squad.HAT)>> </span>
@@ -167,7 +167,7 @@
 	/* <div style="margin-left:2em"><<if _T1 && $SF.Facility.Toggle > 0 && $SF.Facility.Active < 1>>
 	<<set _cSFF = SFUpgradeCost(735000,$SF.Facility.Active)>>
 		<<if $cash >= _cSFF>>
-			[[Build $SF.Lower's support facility|Firebase][$SF.Upgrade = 1, $SF.Facility.Active++, cashX(forceNeg(_cSFF), "specialForces")]]
+			[[Build $SF.Lower's support facility|Firebase][$SF.Upgrade = 1, $SF.Colonel.Talk += 1, $SF.Facility.Active++, cashX(forceNeg(_cSFF), "specialForces")]]
 		<<else>>//Cannot afford to build $SF.Lower's support facility.//<</if>>
 	//Costs @@.red;<<print cashFormat(_cSFF)>>@@//
 	<</if>>*/
diff --git a/src/art/assistantArt.js b/src/art/assistantArt.js
index 5b8130f2031086c0f84ce7fa9ba2991542877e5a..7c7dc326b3410507756769250d67b1398df942f6 100644
--- a/src/art/assistantArt.js
+++ b/src/art/assistantArt.js
@@ -13,56 +13,56 @@ window.assistantArt = function assistantArt(sizePlacement) {
 	if (V.imageChoice === 0 || V.imageChoice === 1) {
 		if (V.imageChoice === 1) {
 			switch (V.assistantAppearance) {
-			case "monstergirl":
-				fileName = "''";
-				break;
-			case "shemale":
-				fileName = "''";
-				break;
-			case "amazon":
-				fileName = "''";
-				break;
-			case "businesswoman":
-				fileName = "''";
-				break;
-			case "goddess":
-				fileName = "''";
-				break;
-			case "hypergoddess":
-				fileName = "''";
-				break;
-			case "schoolgirl":
-				fileName = "''";
-				break;
-			case "angel":
-				fileName = "''";
-				break;
-			case "cherub":
-				fileName = "''";
-				break;
-			case "ERROR_1606_APPEARANCE_FILE_CORRUPT":
-				fileName = "''";
-				break;
-			case "fairy":
-				fileName = "''";
-				break;
-			case "imp":
-				fileName = "''";
-				break;
-			case "incubus":
-				fileName = "''";
-				break;
-			case "pregnant fairy":
-				fileName = "''";
-				break;
-			case "succubus":
-				fileName = "''";
-				break;
-			case "witch":
-				fileName = "''";
-				break;
-			default:
-				fileName = "''";
+				case "monstergirl":
+					fileName = "''";
+					break;
+				case "shemale":
+					fileName = "''";
+					break;
+				case "amazon":
+					fileName = "''";
+					break;
+				case "businesswoman":
+					fileName = "''";
+					break;
+				case "goddess":
+					fileName = "''";
+					break;
+				case "hypergoddess":
+					fileName = "''";
+					break;
+				case "schoolgirl":
+					fileName = "''";
+					break;
+				case "angel":
+					fileName = "''";
+					break;
+				case "cherub":
+					fileName = "''";
+					break;
+				case "ERROR_1606_APPEARANCE_FILE_CORRUPT":
+					fileName = "''";
+					break;
+				case "fairy":
+					fileName = "''";
+					break;
+				case "imp":
+					fileName = "''";
+					break;
+				case "incubus":
+					fileName = "''";
+					break;
+				case "pregnant fairy":
+					fileName = "''";
+					break;
+				case "succubus":
+					fileName = "''";
+					break;
+				case "witch":
+					fileName = "''";
+					break;
+				default:
+					fileName = "''";
 			}
 		} else /* V.imageChoice === 0*/ {
 			fileName += "'resources/renders/assistant ";
diff --git a/src/art/vector/VectorArtJS.js b/src/art/vector/VectorArtJS.js
index 39468cc85b66d2f272a5ab043b5368c4e11f1723..6430d653690fc4a0f3e0fca1c0c55c9c77916c3c 100644
--- a/src/art/vector/VectorArtJS.js
+++ b/src/art/vector/VectorArtJS.js
@@ -1031,9 +1031,9 @@ window.VectorArt = (function () {
 							r += jsInclude("Art_Vector_Dildo_Huge");
 						else if (slave.vaginalAccessory === "long, huge dildo")
 							r += jsInclude("Art_Vector_Dildo_Huge_Long");
-					} else if (slave.vaginalAccessory === "bullet vibrator") {
+					}/* else if (slave.vaginalAccessory === "bullet vibrator" || slave.vaginalAccessory === "smart bullet vibrator") {
 						r += jsInclude("Art_Vector_Bullet_Vibrator");
-					}
+				} */
 			}
 		}
 	}
diff --git a/src/art/vector_revamp/vectorRevampedArtControl.js b/src/art/vector_revamp/vectorRevampedArtControl.js
index 762a4b22599b2306f4dad2e1425c487e47620346..381e46520e2eca963e2a7454ea43ffc96da8b3b5 100644
--- a/src/art/vector_revamp/vectorRevampedArtControl.js
+++ b/src/art/vector_revamp/vectorRevampedArtControl.js
@@ -1403,7 +1403,7 @@ class RevampedArtControl {
 		{
 			case "uncomfortable straps":
 				//if (this.artSlave.boobs >= 300)
-					//result.push("Art_Vector_Revamp_Boob_Outfit_Straps");
+				//result.push("Art_Vector_Revamp_Boob_Outfit_Straps");
 				break;
 			case "a nice maid outfit":
 				if (this.artSlave.boobs >= 300)
diff --git a/src/events/intro/introSummary.tw b/src/events/intro/introSummary.tw
index 0ad9c8ad6dddd5ef6aba4b8629265557ad3f0991..5690b39a8c48071bf43d058ba94e0c7344383c86 100644
--- a/src/events/intro/introSummary.tw
+++ b/src/events/intro/introSummary.tw
@@ -887,12 +887,12 @@ __''Player Character''__
 			<<options $PC.preg>>
 				You are ''<<print $PC.preg>> weeks pregnant with octuplets'' and your
 				water just broke.
-				<<options 0 "Not pregnant" "$PC.pregType = 0, $PC.labor = 0">>
+				<<option 0 "Not pregnant" "$PC.pregType = 0, $PC.labor = 0">>
 			<</options>>
 		<<elseif $PC.preg > 37>>
 			<<options $PC.preg>>
 				You are ''<<print $PC.preg>> weeks pregnant'' and going to go into labor soon.
-				<<options 0 "Not pregnant" "$PC.pregType = 0, $PC.labor = 0">>
+				<<option 0 "Not pregnant" "$PC.pregType = 0, $PC.labor = 0">>
 				<<option 43 "Stuffed to capacity" "$PC.pregType = 8, $PC.labor = 1">>
 			<</options>>
 		<<elseif $PC.preg > 0>>
@@ -1159,6 +1159,8 @@ __''Player Character''__
 <</options>>
 <br>
 
+<<set _exampleSlave = BaseSlave()>>
+
 <<if $seeImages == 1>>
 	<<options $imageChoice>>
 		Using
@@ -1174,6 +1176,10 @@ __''Player Character''__
 			<br>@@.red;Git compiled only, no exceptions.@@
 	<</options>>
 	<<if $imageChoice == 1>>
+		<br>
+		<div style="position:relative;width:200px;height:200px;margin:0 auto;">
+			<<SlaveArt _exampleSlave 0 0>>
+		</div>
 		<br>
 		<<options $seeFaces>>
 			Face art
@@ -1201,7 +1207,15 @@ __''Player Character''__
 			@@.cyan;ENABLED@@ on all images.
 		<</options>>
 	<<elseif $imageChoice == 2>>
+		<br>
+		<div style="position:relative;width:200px;height:200px;margin:0 auto;">
+			<<SlaveArt _exampleSlave 0 0>>
+		</div>
 	<<elseif $imageChoice == 3>>
+		<br>
+		<div style="position:relative;width:200px;height:200px;margin:0 auto;">
+			<<SlaveArt _exampleSlave 0 0>>
+		</div>
 		<br>
 		<<options $seeVectorArtHighlights>>
 			Highlights on shiny clothing
diff --git a/src/facilities/nursery/childInteract.tw b/src/facilities/nursery/childInteract.tw
index 273a723dc2814a66daa5bc82bae51b1a8e753cea..cfa379af387ae86cdef1b5db43c70e51fd74e23c 100644
--- a/src/facilities/nursery/childInteract.tw
+++ b/src/facilities/nursery/childInteract.tw
@@ -151,7 +151,6 @@
 			<</if>>
 		<</if>>
 	<</if>>
-	</span>
 	<<if canDoVaginal($activeChild)>>
 		| <<link "Have another slave fuck $his pussy" "FSlaveSlaveVag">><</link>>
 	<</if>>
diff --git a/src/init/setupVars.tw b/src/init/setupVars.tw
index 4f7b2f2feb50b736466716455cdbad70ba51c8f7..d4fc0bab886973ca288559240644826786db39aa 100644
--- a/src/init/setupVars.tw
+++ b/src/init/setupVars.tw
@@ -2073,6 +2073,7 @@ Then pick _namePool.random(), or display those names as possible choices, or do
 	{name: "No default setting", value: "no default setting"},
 	{name: "None", value: "none"},
 	{name: "Bullet vibrator", value: "bullet vibrator"},
+	{name: "Smart bullet vibrator", value: "smart bullet vibrator"},
 	{name: "Dildo", value: "dildo"},
 	{name: "Long dildo", value: "long dildo", rs: "buyBigDildos"},
 	{name: "Large dildo", value: "large dildo"},
diff --git a/src/init/storyInit.tw b/src/init/storyInit.tw
index 043b157a22ef6a9a6cb2592bb5cb5afa0a17f5a6..9f96d205aae06983d48a63cb8ead06e5c6197b27 100644
--- a/src/init/storyInit.tw
+++ b/src/init/storyInit.tw
@@ -864,6 +864,7 @@ You should have received a copy of the GNU General Public License along with thi
 <<set $toysBoughtVaginalAttachments = 0>>
 <<set $toysBoughtButtPlugs = 0>>
 <<set $toysBoughtButtPlugTails = 0>>
+<<set $toysBoughtSmartVibes = 0>>
 <<set $buckets = 0>>
 
 /* assistant FS appearance variable */
diff --git a/src/js/SlaveState.js b/src/js/SlaveState.js
index bd71ba8d207079835c7252dd10d6b1b31d023a65..cb19ef1633b043421895c8004dd298e1e50b6f24 100644
--- a/src/js/SlaveState.js
+++ b/src/js/SlaveState.js
@@ -1548,6 +1548,7 @@ App.Entity.SlaveState = class SlaveState {
 		 * may accept strings, use at own risk
 		 * * "none"
 		 * * "bullet vibrator"
+		 * * "smart bullet vibrator"
 		 * * "dildo"
 		 * * "large dildo"
 		 * * "huge dildo"
diff --git a/src/js/assignJS.js b/src/js/assignJS.js
index 9da3181848dfbc01a886c0b744183d6c65365224..af4e705db55b4d878bf93b50689114b12693ee17 100644
--- a/src/js/assignJS.js
+++ b/src/js/assignJS.js
@@ -372,139 +372,139 @@ window.removeJob = function removeJob(slave, assignment) {
 
 		/* use .toLowerCase() to get rid of a few dupe conditions. */
 		switch (assignment.toLowerCase()) {
-		case "be confined in the arcade":
-		case "arcade":
-			slave.assignment = "work a glory hole";
-			V.ArcadeiIDs.delete(slave.ID);
-			V.arcadeSlaves--;
-			break;
-
-		case "work in the brothel":
-		case "brothel":
-			slave.assignment = "whore";
-			V.BrothiIDs.delete(slave.ID);
-			V.brothelSlaves--;
-			break;
-
-		case "be confined in the cellblock":
-		case "cellblock":
-			slave.assignment = "rest";
-			if (slave.inflation > 0) {
-				slave.inflation = 0;
-				slave.inflationType = "none";
-				slave.inflationMethod = 0;
-				SetBellySize(slave);
-			}
-			V.CellBiIDs.delete(slave.ID);
-			V.cellblockSlaves--;
-			break;
-
-		case "get treatment in the clinic":
-		case "clinic":
-			slave.assignment = "rest";
-			V.CliniciIDs.delete(slave.ID);
-			V.clinicSlaves--;
-			break;
-
-		case "serve in the club":
-		case "club":
-			slave.assignment = "serve the public";
-			V.ClubiIDs.delete(slave.ID);
-			V.clubSlaves--;
-			break;
-
-		case "work in the dairy":
-		case "dairy":
-			slave.assignment = "get milked";
-			V.DairyiIDs.delete(slave.ID);
-			V.dairySlaves--;
-			break;
-
-		case "work as a farmhand":
-		case "farmyard":
-			slave.assignment = "rest";
-			V.FarmyardiIDs.delete(slave.ID);
-			V.farmyardSlaves--;
-			break;
-
-		case "learn in the schoolroom":
-		case "schoolroom":
-			slave.assignment = "rest";
-			V.SchlRiIDs.delete(slave.ID);
-			V.schoolroomSlaves--;
-			break;
-
-		case "rest in the spa":
-		case "spa":
-			slave.assignment = "rest";
-			V.SpaiIDs.delete(slave.ID);
-			V.spaSlaves--;
-			break;
-
-		case "work as a servant":
-		case "servants' quarters":
-		case "servantsquarters":
-			slave.assignment = "be a servant";
-			V.ServQiIDs.delete(slave.ID);
-			V.servantsQuartersSlaves--;
-			break;
-
-		case "serve in the master suite":
-		case "master suite":
-		case "mastersuite":
-			slave.assignment = "please you";
-			V.MastSiIDs.delete(slave.ID);
-			V.masterSuiteSlaves--;
-			break;
-
-		case "live with your head girl":
-		case "head girl suite":
-		case "hgsuite":
-			slave.assignment = "rest";
-			V.HGSuiteiIDs.delete(slave.ID);
-			V.HGSuiteSlaves--;
-			break;
-
-		case "work as a nanny":
-		case "nursery":
-			slave.assignment = "rest";
-			V.NurseryiIDs.delete(slave.ID);
-			V.nurserySlaves--;
-			break;
-
-		case "be your head girl":
-			slave.assignment = "rest";
-			if (V.HGSuiteEquality === 0 && V.personalAttention === "HG") {
-				if (V.PC.career === "escort")
-					V.personalAttention = "whoring";
-				else if (V.PC.career === "servant")
-					V.personalAttention = "upkeep";
-				else
-					V.personalAttention = "business";
-
-				r += `You no longer have a slave assigned to be your Head Girl, so you turn your personal attention to focus on ${V.personalAttention}.`;
-			}
-			break;
-
-		case "be your agent":
-		case "live with your agent":
-			slave.assignment = "rest";
-			const _leaderIndex = V.leaders.findIndex(function(x) { return x.ID === slave.ID; });
-			if (_leaderIndex !== -1)
-				V.leaders.deleteAt(_leaderIndex);
-
-			if (slave.relationshipTarget > 0) { /* following code assumes there can be at most one companion */
-				const _lover = V.slaves.findIndex(function(s) { return haveRelationshipP(s, slave) && s.assignment === "live with your agent"; });
-				if (_lover !== -1) {
-					V.slaves[_lover].assignment = "rest";
-					V.slaves[_lover].assignmentVisible = 1;
+			case "be confined in the arcade":
+			case "arcade":
+				slave.assignment = "work a glory hole";
+				V.ArcadeiIDs.delete(slave.ID);
+				V.arcadeSlaves--;
+				break;
+
+			case "work in the brothel":
+			case "brothel":
+				slave.assignment = "whore";
+				V.BrothiIDs.delete(slave.ID);
+				V.brothelSlaves--;
+				break;
+
+			case "be confined in the cellblock":
+			case "cellblock":
+				slave.assignment = "rest";
+				if (slave.inflation > 0) {
+					slave.inflation = 0;
+					slave.inflationType = "none";
+					slave.inflationMethod = 0;
+					SetBellySize(slave);
 				}
-			}
-			break;
+				V.CellBiIDs.delete(slave.ID);
+				V.cellblockSlaves--;
+				break;
+
+			case "get treatment in the clinic":
+			case "clinic":
+				slave.assignment = "rest";
+				V.CliniciIDs.delete(slave.ID);
+				V.clinicSlaves--;
+				break;
+
+			case "serve in the club":
+			case "club":
+				slave.assignment = "serve the public";
+				V.ClubiIDs.delete(slave.ID);
+				V.clubSlaves--;
+				break;
+
+			case "work in the dairy":
+			case "dairy":
+				slave.assignment = "get milked";
+				V.DairyiIDs.delete(slave.ID);
+				V.dairySlaves--;
+				break;
+
+			case "work as a farmhand":
+			case "farmyard":
+				slave.assignment = "rest";
+				V.FarmyardiIDs.delete(slave.ID);
+				V.farmyardSlaves--;
+				break;
+
+			case "learn in the schoolroom":
+			case "schoolroom":
+				slave.assignment = "rest";
+				V.SchlRiIDs.delete(slave.ID);
+				V.schoolroomSlaves--;
+				break;
+
+			case "rest in the spa":
+			case "spa":
+				slave.assignment = "rest";
+				V.SpaiIDs.delete(slave.ID);
+				V.spaSlaves--;
+				break;
+
+			case "work as a servant":
+			case "servants' quarters":
+			case "servantsquarters":
+				slave.assignment = "be a servant";
+				V.ServQiIDs.delete(slave.ID);
+				V.servantsQuartersSlaves--;
+				break;
+
+			case "serve in the master suite":
+			case "master suite":
+			case "mastersuite":
+				slave.assignment = "please you";
+				V.MastSiIDs.delete(slave.ID);
+				V.masterSuiteSlaves--;
+				break;
+
+			case "live with your head girl":
+			case "head girl suite":
+			case "hgsuite":
+				slave.assignment = "rest";
+				V.HGSuiteiIDs.delete(slave.ID);
+				V.HGSuiteSlaves--;
+				break;
+
+			case "work as a nanny":
+			case "nursery":
+				slave.assignment = "rest";
+				V.NurseryiIDs.delete(slave.ID);
+				V.nurserySlaves--;
+				break;
+
+			case "be your head girl":
+				slave.assignment = "rest";
+				if (V.HGSuiteEquality === 0 && V.personalAttention === "HG") {
+					if (V.PC.career === "escort")
+						V.personalAttention = "whoring";
+					else if (V.PC.career === "servant")
+						V.personalAttention = "upkeep";
+					else
+						V.personalAttention = "business";
+
+					r += `You no longer have a slave assigned to be your Head Girl, so you turn your personal attention to focus on ${V.personalAttention}.`;
+				}
+				break;
+
+			case "be your agent":
+			case "live with your agent":
+				slave.assignment = "rest";
+				const _leaderIndex = V.leaders.findIndex(function(x) { return x.ID === slave.ID; });
+				if (_leaderIndex !== -1)
+					V.leaders.deleteAt(_leaderIndex);
+
+				if (slave.relationshipTarget > 0) { /* following code assumes there can be at most one companion */
+					const _lover = V.slaves.findIndex(function(s) { return haveRelationshipP(s, slave) && s.assignment === "live with your agent"; });
+					if (_lover !== -1) {
+						V.slaves[_lover].assignment = "rest";
+						V.slaves[_lover].assignmentVisible = 1;
+					}
+				}
+				break;
 
-		default:
-			slave.assignment = "rest";
-			break;
+			default:
+				slave.assignment = "rest";
+				break;
 		}
 
 		if (slave.livingRules === "luxurious" && slave.assignmentVisible !== 1)
diff --git a/src/js/extendedFamilyModeJS.js b/src/js/extendedFamilyModeJS.js
index 3e6d2ac7575d089088602324b54b2371a667aaa4..03c73b2779f1c382c7a8fd2a6658f9b2f7430541 100644
--- a/src/js/extendedFamilyModeJS.js
+++ b/src/js/extendedFamilyModeJS.js
@@ -165,8 +165,8 @@ window.areCousins = /** @param {App.Entity.SlaveState} slave1, @param {App.Entit
 
 window.areRelated = /** @param {App.Entity.SlaveState} slave1, @param {App.Entity.SlaveState} slave2 */
 	function (slave1, slave2) {
-	return (slave1.father === slave2.ID || slave1.mother === slave2.ID || slave2.father === slave1.ID || slave2.mother === slave1.ID || areSisters(slave1, slave2) > 0);
-};
+		return (slave1.father === slave2.ID || slave1.mother === slave2.ID || slave2.father === slave1.ID || slave2.mother === slave1.ID || areSisters(slave1, slave2) > 0);
+	};
 
 window.totalRelatives = /** @param {App.Entity.SlaveState} slave */ function (slave) {
 	var relatives = 0;
diff --git a/src/js/familyTreeJS.js b/src/js/familyTreeJS.js
index 7e6ef9826562d8f81c58c6f3a0b291f474b915b2..4f78035bb341eb070519ed791c6fb0a2984f26ba 100644
--- a/src/js/familyTreeJS.js
+++ b/src/js/familyTreeJS.js
@@ -111,9 +111,9 @@ window.renderFamilyTree = function(slaves, filterID) {
 			.enter().append('g')
 			.attr('class', 'node')
 			.call(d3.drag()
-			.on('start', dragstarted)
-			.on('drag', dragged)
-			.on('end', dragended));
+				.on('start', dragstarted)
+				.on('drag', dragged)
+				.on('end', dragended));
 
 		node.append('circle')
 			.attr('r', function (d) { return d.r; })
@@ -509,118 +509,118 @@ window.updateFamilyTree = function(activeSlave = lastActiveSlave, slaves = lastS
 		for(let i = 0; i < slaves.length; ++i) {
 			if(slaves[i].ID === id)
 				return slaves[i];
-			}
-		return {"slaveName":"-", "ID":id, "genes":expectedGenes};
 		}
+		return {"slaveName":"-", "ID":id, "genes":expectedGenes};
+	}
 
 	function slaveInfo(slave, activeSlaveId, recursionProtectSlaveId = {}) {
-	numTreeNodes = 0;
-	treeDepth = 0;
-	if(recursionProtectSlaveId[slave.ID]) {
-		console.log("Recursion protection");
-		return slaveInfo_(slave, activeSlaveId);
-	}
-	recursionProtectSlaveId[slave.ID] = true;
+		numTreeNodes = 0;
+		treeDepth = 0;
+		if(recursionProtectSlaveId[slave.ID]) {
+			console.log("Recursion protection");
+			return slaveInfo_(slave, activeSlaveId);
+		}
+		recursionProtectSlaveId[slave.ID] = true;
 
-	if(typeof slave.father === "undefined" || typeof slave.mother === "undefined")
-		return slaveInfo_(slave, activeSlaveId);
+		if(typeof slave.father === "undefined" || typeof slave.mother === "undefined")
+			return slaveInfo_(slave, activeSlaveId);
 
-	if(slave.father === -1 || slave.mother === -1) {
-		return slaveInfo(getSlave(-1), activeSlaveId, recursionProtectSlaveId);
-	}
-	if(slave.father !== 0) {
-		return slaveInfo(getSlave(slave.father, "unknownXY"), activeSlaveId, recursionProtectSlaveId);
-	}
+		if(slave.father === -1 || slave.mother === -1) {
+			return slaveInfo(getSlave(-1), activeSlaveId, recursionProtectSlaveId);
+		}
+		if(slave.father !== 0) {
+			return slaveInfo(getSlave(slave.father, "unknownXY"), activeSlaveId, recursionProtectSlaveId);
+		}
 
-	if(slave.mother !== 0) {
-		return slaveInfo(getSlave(slave.mother, "unknownXX"), activeSlaveId, recursionProtectSlaveId);
-	}
-	return slaveInfo_(slave, activeSlaveId);
+		if(slave.mother !== 0) {
+			return slaveInfo(getSlave(slave.mother, "unknownXX"), activeSlaveId, recursionProtectSlaveId);
+		}
+		return slaveInfo_(slave, activeSlaveId);
 	}
 	function slaveInfo_(slave, activeSlaveId, slavesAdded={}, depth = 1) {
-	numTreeNodes += 1;
-	treeDepth = Math.max(treeDepth, depth);
-	var shouldAddChildren = false;
-	if(!slavesAdded[slave.ID]) {
-		shouldAddChildren = true;
-		slavesAdded[slave.ID] = true;
-	}
-	var data = {
-		"name": slave.slaveName + (slave.physicalAge?("&nbsp;(" + slave.physicalAge + ")"):""),
-		"class" : slave.genes,
-		"textClass": (activeSlaveId === slave.ID)?"emphasis":"",
-		"marriages": [],
-	};
+		numTreeNodes += 1;
+		treeDepth = Math.max(treeDepth, depth);
+		var shouldAddChildren = false;
+		if(!slavesAdded[slave.ID]) {
+			shouldAddChildren = true;
+			slavesAdded[slave.ID] = true;
+		}
+		var data = {
+			"name": slave.slaveName + (slave.physicalAge?("&nbsp;(" + slave.physicalAge + ")"):""),
+			"class" : slave.genes,
+			"textClass": (activeSlaveId === slave.ID)?"emphasis":"",
+			"marriages": [],
+		};
 
-	var spouseToChild = {};
+		var spouseToChild = {};
 
-	function maybeAddSpouseToChild(child) {
-		if(child.ID === slave.ID)
-		return;
-		if (child.father === slave.ID) {
-		if(!spouseToChild[child.mother]) {
-			spouseToChild[child.mother] = [];
-		}
-		spouseToChild[child.mother].push(child);
-		} else if (child.mother === slave.ID) {
-		if(!spouseToChild[child.father]) {
-			spouseToChild[child.father] = [];
-		}
-		spouseToChild[child.father].push(child);
+		function maybeAddSpouseToChild(child) {
+			if(child.ID === slave.ID)
+				return;
+			if (child.father === slave.ID) {
+				if(!spouseToChild[child.mother]) {
+					spouseToChild[child.mother] = [];
+				}
+				spouseToChild[child.mother].push(child);
+			} else if (child.mother === slave.ID) {
+				if(!spouseToChild[child.father]) {
+					spouseToChild[child.father] = [];
+				}
+				spouseToChild[child.father].push(child);
+			}
 		}
-	}
 
-	if(activeSlave.ID !== PC.ID)
-		maybeAddSpouseToChild(activeSlave);
+		if(activeSlave.ID !== PC.ID)
+			maybeAddSpouseToChild(activeSlave);
 		maybeAddSpouseToChild(getSlave(-1));
 
-	for(let i = 0; i < slaves.length; ++i) {
-		var child = slaves[i];
-		if(child.ID !== activeSlave.ID)
-		maybeAddSpouseToChild(child);
-	}
-
-	for(let key in spouseToChild) {
-		if(spouseToChild.hasOwnProperty(key)) {
-			var children = shouldAddChildren?spouseToChild[key]:[];
-			var spouse = getSlave(key, (slaves.genes === "XX")?"unknownXY":(slaves.genes === "XY")?"unknownXX":"unknown");
-			var spouseName;
-			if (spouse.ID !== slave.ID){
-				spouseName = spouse.slaveName + (spouse.physicalAge?("&nbsp;(" + spouse.physicalAge + ")"):"");
-			} else {
-				spouseName = (spouse.ID === -1)?"(yourself)":"(themselves)";
-			}
-			var marriage = {
-				"spouse": {"name": spouseName, "class": spouse.genes},
-				"children": children.map(function (x) { return slaveInfo_(x, activeSlaveId, slavesAdded, depth + 1);} ),	/** FIXME: Functions declared within loops referencing an outer scoped variable may lead to confusing semantics. (slaveInfo_, activeSlaveId, slavesAdded, depth) (W083)jshint(W083) */
-			};
-			data.marriages.push(marriage);
+		for(let i = 0; i < slaves.length; ++i) {
+			var child = slaves[i];
+			if(child.ID !== activeSlave.ID)
+				maybeAddSpouseToChild(child);
+		}
+
+		for(let key in spouseToChild) {
+			if(spouseToChild.hasOwnProperty(key)) {
+				var children = shouldAddChildren?spouseToChild[key]:[];
+				var spouse = getSlave(key, (slaves.genes === "XX")?"unknownXY":(slaves.genes === "XY")?"unknownXX":"unknown");
+				var spouseName;
+				if (spouse.ID !== slave.ID){
+					spouseName = spouse.slaveName + (spouse.physicalAge?("&nbsp;(" + spouse.physicalAge + ")"):"");
+				} else {
+					spouseName = (spouse.ID === -1)?"(yourself)":"(themselves)";
+				}
+				var marriage = {
+					"spouse": {"name": spouseName, "class": spouse.genes},
+					"children": children.map(function (x) { return slaveInfo_(x, activeSlaveId, slavesAdded, depth + 1);} ),	/** FIXME: Functions declared within loops referencing an outer scoped variable may lead to confusing semantics. (slaveInfo_, activeSlaveId, slavesAdded, depth) (W083)jshint(W083) */
+				};
+				data.marriages.push(marriage);
 			}
 		}
-	return data;
+		return data;
 	}
 
 	if (activeSlave === PC || activeSlave === null)
 		activeSlave = getSlave(-1);
-		const treeData = [slaveInfo(activeSlave, activeSlave.ID)];
-		console.log("Family tree is", treeData, 'and has:', numTreeNodes);
+	const treeData = [slaveInfo(activeSlave, activeSlave.ID)];
+	console.log("Family tree is", treeData, 'and has:', numTreeNodes);
 
-		var parentWidth = document.getElementById('editFamily').offsetWidth;
+	var parentWidth = document.getElementById('editFamily').offsetWidth;
 
-		console.log(parentWidth, document.getElementById('passages').offsetWidth);
-		if(!parentWidth)
-			parentWidth = document.body.offsetWidth - 483;
+	console.log(parentWidth, document.getElementById('passages').offsetWidth);
+	if(!parentWidth)
+		parentWidth = document.body.offsetWidth - 483;
 
-			console.log(parentWidth, Math.min(200 + 40*numTreeNodes,parentWidth-200) + 200);
+	console.log(parentWidth, Math.min(200 + 40*numTreeNodes,parentWidth-200) + 200);
 
-			dTree.init(treeData, {
-			target: "#graph",
-			debug: true,
-			height: 50 + 50*treeDepth, /* very rough heuristics */
-			width: Math.min(200 + 40*numTreeNodes,
-					parentWidth-200) + 200,
-			callbacks: {
-				nodeClick: function(/*name, extra*/) {
+	dTree.init(treeData, {
+		target: "#graph",
+		debug: true,
+		height: 50 + 50*treeDepth, /* very rough heuristics */
+		width: Math.min(200 + 40*numTreeNodes,
+			parentWidth-200) + 200,
+		callbacks: {
+			nodeClick: function(/*name, extra*/) {
 			}
 		}
 	});
diff --git a/src/js/generateGenetics.js b/src/js/generateGenetics.js
index 0f0afc00e58a7b7e0cb311bb093267a27327c1a4..dd429417f44902f79494a973e8d90371d6283ac3 100644
--- a/src/js/generateGenetics.js
+++ b/src/js/generateGenetics.js
@@ -179,7 +179,7 @@ window.generateGenetics = (function() {
 	function setNationality(father, mother) {
 		return (father === 0) ? "Stateless"
 			: (father.nationality === mother.nationality) ? mother.nationality
-			: "Stateless";
+				: "Stateless";
 	}
 
 	// race
@@ -187,8 +187,8 @@ window.generateGenetics = (function() {
 		let race;
 		if (father !== 0) {
 			race = (mother.origRace === father.origRace) ? mother.origRace
-			: (jsRandom(1,4)) === 4 ? jsEither([father.origRace, mother.origRace])
-			: "mixed race";
+				: (jsRandom(1,4)) === 4 ? jsEither([father.origRace, mother.origRace])
+					: "mixed race";
 		} else if (actor2 === -2 || actor2 === -5) {
 			if (V.arcologies[0].FSSupremacist !== "unset") {
 				race = jsEither([mother.origRace, V.arcologies[0].FSSupremacistRace, V.arcologies[0].FSSupremacistRace]);
diff --git a/src/js/generateNewSlaveJS.js b/src/js/generateNewSlaveJS.js
index 80f4198597ce2c16f646e63389d429cde71a3a03..796670cd364e7416efdf276b5a83d26380043647 100644
--- a/src/js/generateNewSlaveJS.js
+++ b/src/js/generateNewSlaveJS.js
@@ -1449,41 +1449,41 @@ window.GenerateNewSlave = (function(){
 				while (disList.length > 0) {
 					let rolled = jsEither(disList);
 					switch (rolled) {
-					case "hearNot":
-						if ((jsRandom(1,100)-(disableCount*2)) > 90) {
-							slave.hears = -2;
-						}
-						disList.delete("hearNot");
-						disableCount++;
-						break;
-					case "seeNot":
-						if ((jsRandom(1,100)-(disableCount*2)) > 90) {
-							slave.eyes = -2;
-						}
-						disList.delete("seeNot");
-						disableCount++;
-						break;
-					case "speakNot":
-						if ((jsRandom(1,100)-(disableCount*2)) > 90) {
-							slave.voice = 0;
-						}
-						disList.delete("speakNot");
-						disableCount++;
-						break;
-					case "smellNot":
-						if ((jsRandom(1,100)-(disableCount*2)) > 90) {
-							slave.smells = -1;
-						}
-						disList.delete("smellNot");
-						disableCount++;
-						break;
-					case "tasteNot":
-						if ((jsRandom(1,100)-(disableCount*2)) > 90) {
-							slave.tastes = -1;
-						}
-						disList.delete("tasteNot");
-						disableCount++;
-						break;
+						case "hearNot":
+							if ((jsRandom(1,100)-(disableCount*2)) > 90) {
+								slave.hears = -2;
+							}
+							disList.delete("hearNot");
+							disableCount++;
+							break;
+						case "seeNot":
+							if ((jsRandom(1,100)-(disableCount*2)) > 90) {
+								slave.eyes = -2;
+							}
+							disList.delete("seeNot");
+							disableCount++;
+							break;
+						case "speakNot":
+							if ((jsRandom(1,100)-(disableCount*2)) > 90) {
+								slave.voice = 0;
+							}
+							disList.delete("speakNot");
+							disableCount++;
+							break;
+						case "smellNot":
+							if ((jsRandom(1,100)-(disableCount*2)) > 90) {
+								slave.smells = -1;
+							}
+							disList.delete("smellNot");
+							disableCount++;
+							break;
+						case "tasteNot":
+							if ((jsRandom(1,100)-(disableCount*2)) > 90) {
+								slave.tastes = -1;
+							}
+							disList.delete("tasteNot");
+							disableCount++;
+							break;
 					}
 				}
 			}
diff --git a/src/js/itemAvailability.js b/src/js/itemAvailability.js
index dd500ccf50249eb640389b4ad114ea334f6825bd..a9aceb8a6a8a006f5713c7d0f0d21369de23335c 100644
--- a/src/js/itemAvailability.js
+++ b/src/js/itemAvailability.js
@@ -139,6 +139,7 @@ window.isItemAccessible = function(string) {
 		case 'a huge empathy belly':
 			return (V.arcologies[0].FSRepopulationFocus > 0 || V.clothesBoughtBelly === 1);
 		case 'bullet vibrator':
+		case 'smart bullet vibrator':
 		case 'long dildo':
 		case 'long, large dildo':
 		case 'long, huge dildo':
diff --git a/src/js/optionsMacro.js b/src/js/optionsMacro.js
index 3e089e5815aaaf2e5a826bdbfec06d9de81d6e77..bbf725a57cc0cb0508ade6e23a9e702cbbfd5a14 100644
--- a/src/js/optionsMacro.js
+++ b/src/js/optionsMacro.js
@@ -1,3 +1,4 @@
+/* eslint-disable no-empty */
 /* eslint-disable no-console */
 /* eslint-disable no-undef */
 /* Use like:
@@ -31,12 +32,13 @@ Macro.add('options', {
 			var comment = null;
 			var hasMultipleOptionsWithSameValue = false;
 			var description = "";
+			var hasCurrentOption = this.payload[0].args.full &&
+			this.payload[0].args.full !== '""' && this.payload[0].args.full !== "''";
 
 			/* Check if we have a first argument - if we do, it should be a
 			   variable like $foo
 			  */
-			if (this.payload[0].args.full &&
-					this.payload[0].args.full !== '""' && this.payload[0].args.full !== "''") {
+			if (hasCurrentOption) {
 				if (currentOption === undefined)
 					currentOption = false;
 				if (this.payload[0].args.full.startsWith("State.temporary.")) {
@@ -95,6 +97,21 @@ Macro.add('options', {
 						throw new Error("Only valid tag is 'option' inside 'options'");
 					}
 				}
+			} else {
+				// No variable was passed to <<options>>
+				// This is valid, but then we only allow an empty <<option>> or <<comment>>
+				// inside
+				for (let i = 1, len = this.payload.length; i < len; ++i) {
+					if (this.payload[i].name === 'option' && this.payload[i].args.length === 0) {
+						// This is valid for an empty <<options>>
+					} else if (this.payload[i].name === "comment") {
+						// This is valid for an empty <<options>>
+					} else {
+						throw new Error("Missing variable to <<options>>");
+					}
+
+				}
+
 			}
 
 			var showSelectedOption = true; //this.payload.length !== 3 || !description;
diff --git a/src/js/quickListJS.js b/src/js/quickListJS.js
index b9cfec3f418ba29127880904a7d3437f5ab12dd8..66f91135143c858f09bd7aef04c43d3156ba3168 100644
--- a/src/js/quickListJS.js
+++ b/src/js/quickListJS.js
@@ -33,8 +33,8 @@ window.quickListBuildLinks = function () {
 		var $this = $(this), $toElement = $this.attr('data-scroll-to');
 		// note the * 1 enforces $offset to be an integer, without
 		// it we scroll to True, which goes nowhere fast.
-				var $offset = $this.attr('data-scroll-offset') * 1 || 0;
-				var $speed = $this.attr('data-scroll-speed') * 1 || 500;
+		var $offset = $this.attr('data-scroll-offset') * 1 || 0;
+		var $speed = $this.attr('data-scroll-speed') * 1 || 500;
 		// Use javascript scrollTop animation for in page navigation.
 		$('html, body').animate({
 			scrollTop: $($toElement).offset().top + $offset
diff --git a/src/js/rbuttonJS.js b/src/js/rbuttonJS.js
index 06ff286cd4942cb79649c975b599252f20a91c30..8c37e7336e3da3cdf4b56975ae41eb9b304c04ba 100644
--- a/src/js/rbuttonJS.js
+++ b/src/js/rbuttonJS.js
@@ -12,22 +12,22 @@ Group of radiobutton will be created based on variable name. Checked state will
 Macro.add('rbutton', {
 	handler() {
 		if (this.args.length < 2) {
-		const errors = [];
-		if (this.args.length < 1) { errors.push('variable name'); }
-		if (this.args.length < 2) { errors.push('checked value'); }
-		return this.error(`no ${errors.join(' or ')} specified`);
+			const errors = [];
+			if (this.args.length < 1) { errors.push('variable name'); }
+			if (this.args.length < 2) { errors.push('checked value'); }
+			return this.error(`no ${errors.join(' or ')} specified`);
 		}
 
 		// Ensure that the variable name argument is a string.
 		if (typeof this.args[0] !== 'string') {
-		return this.error('variable name argument is not a string');
+			return this.error('variable name argument is not a string');
 		}
 
 		const varName = this.args[0].trim();
 
 		// Try to ensure that we receive the variable's name (incl. sigil), not its value.
 		if (varName[0] !== '$' && varName[0] !== '_') {
-		return this.error(`variable name "${this.args[0]}" is missing its sigil ($ or _)`);
+			return this.error(`variable name "${this.args[0]}" is missing its sigil ($ or _)`);
 		}
 
 		const initValue = Wikifier.getValue(this.args[0]);
@@ -48,59 +48,59 @@ Macro.add('rbutton', {
 		Setup and initialize the group counter.
 		*/
 		if (!TempState.hasOwnProperty(this.name)) {
-		TempState[this.name] = {};
+			TempState[this.name] = {};
 		}
 
 		if (!TempState[this.name].hasOwnProperty(varId)) {
-		TempState[this.name][varId] = 0;
+			TempState[this.name][varId] = 0;
 		}
 
 		/*
 		Setup and append the input element to the output buffer.
 		*/
 		jQuery(el)
-		.attr({
-			id : `${this.name}-${varId}-${TempState[this.name][varId]++}`,
-			name : `${this.name}-${varId}`,
-			type : 'radio',
-			tabindex : 0 // for accessibility
-		})
-		.addClass(`macro-${this.name}`)
-		.on('change', function () {
-			if (this.checked) {
-			Wikifier.setValue(varName, checkValue);
-
-			if (replaceID.length > 0 && replaceText.length > 0){
+			.attr({
+				id : `${this.name}-${varId}-${TempState[this.name][varId]++}`,
+				name : `${this.name}-${varId}`,
+				type : 'radio',
+				tabindex : 0 // for accessibility
+			})
+			.addClass(`macro-${this.name}`)
+			.on('change', function () {
+				if (this.checked) {
+					Wikifier.setValue(varName, checkValue);
+
+					if (replaceID.length > 0 && replaceText.length > 0){
+
+						var replaceEl = document.getElementById(replaceID);
+						//alert (replaceEl);
+						if (replaceEl !== null) {
+							replaceEl.innerHTML = replaceText;
+						}
 
-				var replaceEl = document.getElementById(replaceID);
-				//alert (replaceEl);
-				if (replaceEl !== null) {
-					replaceEl.innerHTML = replaceText;
 					}
-
 				}
-			}
-		})
-		.ready (function () {
+			})
+			.ready (function () {
 			//alert ("DOM finished");
-			if (el.checked && replaceID.length > 0 && replaceText.length > 0){
+				if (el.checked && replaceID.length > 0 && replaceText.length > 0){
 
-				var replaceEl = document.getElementById(replaceID);
-				//alert (replaceEl);
-				if (replaceEl !== null) {
-					replaceEl.innerHTML = replaceText;
-				}
+					var replaceEl = document.getElementById(replaceID);
+					//alert (replaceEl);
+					if (replaceEl !== null) {
+						replaceEl.innerHTML = replaceText;
+					}
 
-			}
-		})
-		.appendTo(this.output);
+				}
+			})
+			.appendTo(this.output);
 
 		/*
 		Set the story variable to the checked value and the input element to checked, if requested.
 		*/
 		if (initValue === checkValue) {
-		el.checked = true;
-		Wikifier.setValue(varName, checkValue);
+			el.checked = true;
+			Wikifier.setValue(varName, checkValue);
 		}
 	}
 });
diff --git a/src/js/removeActiveSlave.js b/src/js/removeActiveSlave.js
index 2844d619479bbf732b57ac33d2264750cf0fea5a..4b20f23fe4568dadc53f1965ab9df19c448f2366 100644
--- a/src/js/removeActiveSlave.js
+++ b/src/js/removeActiveSlave.js
@@ -141,8 +141,8 @@ window.removeActiveSlave = function removeActiveSlave() {
 			}
 		}
 
-			/* Remove from facility array or leadership role, if needed */
-			removeJob(V.activeSlave, V.activeSlave.assignment);
+		/* Remove from facility array or leadership role, if needed */
+		removeJob(V.activeSlave, V.activeSlave.assignment);
 
 		if (V.traitor !== 0) {
 			missing = true; /* no exceptions, fetus system relies on this */
diff --git a/src/js/rulesAssistant.js b/src/js/rulesAssistant.js
index 7a86300876ee1bb426a4f9061de2ab6c7a793c39..5d6c2d3ca92433d4f9850394b7f6798c2c4aba5f 100644
--- a/src/js/rulesAssistant.js
+++ b/src/js/rulesAssistant.js
@@ -63,96 +63,96 @@ window.RAFacilityRemove = function RAFacilityRemove(slave, rule) {
 	let r = "";
 	if (!rule.facilityRemove) return r;
 	switch(rule.setAssignment) {
-	case "be confined in the arcade":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.arcadeName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "be confined in the arcade":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.arcadeName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "work in the brothel":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.brothelName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "work in the brothel":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.brothelName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "serve in the club":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${clubName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "serve in the club":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${clubName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "work in the dairy":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.dairyName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "work in the dairy":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.dairyName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "work as farmhand":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.farmyardName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave. rule.removalAssignment);
-		}
-		break;
+		case "work as farmhand":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.farmyardName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave. rule.removalAssignment);
+			}
+			break;
 
-	case "rest in the spa":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.spaName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "rest in the spa":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.spaName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "work as a nanny":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.nurseryName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "work as a nanny":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.nurseryName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "get treatment in the clinic":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>{slave.slaveName} has been removed from ${V.clinicName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "get treatment in the clinic":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>{slave.slaveName} has been removed from ${V.clinicName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "serve in the master suite":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>{slave.slaveName} has been removed from ${V.masterSuiteName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "serve in the master suite":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>{slave.slaveName} has been removed from ${V.masterSuiteName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "live with your Head Girl":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${HGSuiteName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "live with your Head Girl":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${HGSuiteName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "work as a servant":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.servantsQuartersName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "work as a servant":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.servantsQuartersName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "learn in the schoolroom":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.schoolroomName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "learn in the schoolroom":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.schoolroomName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 
-	case "be confined in the cellblock":
-		if (slave.assignment === rule.setAssignment) {
-			r += `<br>${slave.slaveName} has been removed from ${V.cellblockName} and has been assigned to ${rule.removalAssignment}.`;
-			assignJob(slave, rule.removalAssignment);
-		}
-		break;
+		case "be confined in the cellblock":
+			if (slave.assignment === rule.setAssignment) {
+				r += `<br>${slave.slaveName} has been removed from ${V.cellblockName} and has been assigned to ${rule.removalAssignment}.`;
+				assignJob(slave, rule.removalAssignment);
+			}
+			break;
 	}
 };
 
@@ -163,24 +163,24 @@ window.ruleAppliesP = function ruleAppliesP(cond, slave) {
 
 	// attribute / function check
 	switch (cond.function) {
-	case true: // always applies
-		flag = true;
-		break;
-	case false: // never applies
-		flag = false;
-		break;
-	case "between": // between two values of a slave's attribute
-		flag = between(
-			slave[cond.data.attribute],
-			cond.data.value[0],
-			cond.data.value[1]);
-		break;
-	case "belongs": // the attribute belongs in the list of values
-		flag = cond.data.value.includes(slave[cond.data.attribute]);
-		break;
-	case "custom": // user provided JS function
-		flag = eval(cond.data)(slave);
-		break;
+		case true: // always applies
+			flag = true;
+			break;
+		case false: // never applies
+			flag = false;
+			break;
+		case "between": // between two values of a slave's attribute
+			flag = between(
+				slave[cond.data.attribute],
+				cond.data.value[0],
+				cond.data.value[1]);
+			break;
+		case "belongs": // the attribute belongs in the list of values
+			flag = cond.data.value.includes(slave[cond.data.attribute]);
+			break;
+		case "custom": // user provided JS function
+			flag = eval(cond.data)(slave);
+			break;
 	}
 	// assignment / facility / special slaves / specific slaves check
 	let assignment = slave.assignment;
diff --git a/src/js/rulesAssistantOptions.js b/src/js/rulesAssistantOptions.js
index b4223cc99b4c68202d39659316f844f86cd7799e..8cfd762c643f1d324d2d1de30d2ee2867eb1987c 100644
--- a/src/js/rulesAssistantOptions.js
+++ b/src/js/rulesAssistantOptions.js
@@ -1858,9 +1858,9 @@ window.rulesAssistantOptions = (function() {
 			];
 			if (V.medicalEnema === 1) {
 				enemas.push(
-				["Aphrodisiac", "aphrodisiac"],
-				["Curative", "curative"],
-				["Tightener", "tightener"]
+					["Aphrodisiac", "aphrodisiac"],
+					["Curative", "curative"],
+					["Tightener", "tightener"]
 				);
 			}
 			super("Enemas", enemas);
diff --git a/src/js/rulesAutosurgery.js b/src/js/rulesAutosurgery.js
index 0fbe86aef48da9cb918db7d58d9be8c5a53d151b..3f75b0ac3abfc2dc70c646b7b26d8e38435830e5 100644
--- a/src/js/rulesAutosurgery.js
+++ b/src/js/rulesAutosurgery.js
@@ -35,94 +35,94 @@ window.rulesAutosurgery = (function() {
 	function ProcessHGTastes(slave) {
 		let thisSurgery;
 		switch (V.HGTastes) {
-		case 1:
-			thisSurgery = {
-				surgery_lactation: 0,
-				surgery_cosmetic: 1,
-				surgery_faceShape: "cute",
-				surgery_lips: 10,
-				surgery_hips: 0,
-				surgery_hipsImplant: 0,
-				surgery_butt: 0,
-				surgery_accent: 0,
-				surgery_shoulders: 0,
-				surgery_shouldersImplant: 0,
-				surgery_boobs: 0,
-				surgery_holes: 0
-			};
-			break ;
-		case 2:
-			thisSurgery = {
-				surgery_lactation: 0,
-				surgery_cosmetic: 1,
-				surgery_faceShape: "cute",
-				surgery_lips: 60,
-				surgery_hips: 0,
-				surgery_hipsImplant: 0,
-				surgery_butt: 4,
-				surgery_accent: 0,
-				surgery_shoulders: 0,
-				surgery_shouldersImplant: 0,
-				surgery_boobs: 1200,
-				surgery_holes: 0
-			};
-			break;
-		case 3:
-			thisSurgery = {
-				surgery_lactation: 0,
-				surgery_cosmetic: 1,
-				surgery_faceShape: "cute",
-				surgery_lips: 95,
-				surgery_hips: 0,
-				surgery_hipsImplant: 0,
-				surgery_butt: 8,
-				surgery_accent: 0,
-				surgery_shoulders: 0,
-				surgery_shouldersImplant: 0,
-				surgery_boobs: 10000,
-				surgery_holes: 2
-			};
-			break;
-		case 4:
-			thisSurgery = {
-				surgery_lactation: 1,
-				surgery_cosmetic: 1,
-				surgery_faceShape: "cute",
-				surgery_lips: 10,
-				surgery_hips: 3,
-				surgery_hipsImplant: 0,
-				surgery_butt: 0,
-				surgery_accent: 0,
-				surgery_shoulders: 0,
-				surgery_shouldersImplant: 0,
-				surgery_boobs: 0,
-				surgery_holes: 0
-			};
-			break;
-		default:
-			thisSurgery = autoSurgerySelector(
-				slave,
-				V.defaultRules
-					.filter(x => ruleApplied(slave, x) && x.set.autoSurgery === 1)
-					.map(x => x.set));
-			if ((thisSurgery.surgery_hips !== "no default setting") && (thisSurgery.surgery_butt !== "no default setting")) {
-				if (slave.hips < -1) {
-					if (thisSurgery.surgery_butt > 2)
-						thisSurgery.surgery_butt = 2;
-				} else if (slave.hips < 0) {
-					if (thisSurgery.surgery_butt > 4)
-						thisSurgery.surgery_butt = 4;
-				} else if (slave.hips > 0) {
-					if (thisSurgery.surgery_butt > 8)
-						thisSurgery.surgery_butt = 8;
-				} else if (slave.hips > 1) {
+			case 1:
+				thisSurgery = {
+					surgery_lactation: 0,
+					surgery_cosmetic: 1,
+					surgery_faceShape: "cute",
+					surgery_lips: 10,
+					surgery_hips: 0,
+					surgery_hipsImplant: 0,
+					surgery_butt: 0,
+					surgery_accent: 0,
+					surgery_shoulders: 0,
+					surgery_shouldersImplant: 0,
+					surgery_boobs: 0,
+					surgery_holes: 0
+				};
+				break ;
+			case 2:
+				thisSurgery = {
+					surgery_lactation: 0,
+					surgery_cosmetic: 1,
+					surgery_faceShape: "cute",
+					surgery_lips: 60,
+					surgery_hips: 0,
+					surgery_hipsImplant: 0,
+					surgery_butt: 4,
+					surgery_accent: 0,
+					surgery_shoulders: 0,
+					surgery_shouldersImplant: 0,
+					surgery_boobs: 1200,
+					surgery_holes: 0
+				};
+				break;
+			case 3:
+				thisSurgery = {
+					surgery_lactation: 0,
+					surgery_cosmetic: 1,
+					surgery_faceShape: "cute",
+					surgery_lips: 95,
+					surgery_hips: 0,
+					surgery_hipsImplant: 0,
+					surgery_butt: 8,
+					surgery_accent: 0,
+					surgery_shoulders: 0,
+					surgery_shouldersImplant: 0,
+					surgery_boobs: 10000,
+					surgery_holes: 2
+				};
+				break;
+			case 4:
+				thisSurgery = {
+					surgery_lactation: 1,
+					surgery_cosmetic: 1,
+					surgery_faceShape: "cute",
+					surgery_lips: 10,
+					surgery_hips: 3,
+					surgery_hipsImplant: 0,
+					surgery_butt: 0,
+					surgery_accent: 0,
+					surgery_shoulders: 0,
+					surgery_shouldersImplant: 0,
+					surgery_boobs: 0,
+					surgery_holes: 0
+				};
+				break;
+			default:
+				thisSurgery = autoSurgerySelector(
+					slave,
+					V.defaultRules
+						.filter(x => ruleApplied(slave, x) && x.set.autoSurgery === 1)
+						.map(x => x.set));
+				if ((thisSurgery.surgery_hips !== "no default setting") && (thisSurgery.surgery_butt !== "no default setting")) {
+					if (slave.hips < -1) {
+						if (thisSurgery.surgery_butt > 2)
+							thisSurgery.surgery_butt = 2;
+					} else if (slave.hips < 0) {
+						if (thisSurgery.surgery_butt > 4)
+							thisSurgery.surgery_butt = 4;
+					} else if (slave.hips > 0) {
+						if (thisSurgery.surgery_butt > 8)
+							thisSurgery.surgery_butt = 8;
+					} else if (slave.hips > 1) {
 					// true
-				} else {
-					if (thisSurgery.surgery_butt > 6)
-						thisSurgery.surgery_butt = 6;
+					} else {
+						if (thisSurgery.surgery_butt > 6)
+							thisSurgery.surgery_butt = 6;
+					}
 				}
-			}
-			break;
+				break;
 		}
 		return thisSurgery;
 	}
@@ -157,28 +157,28 @@ window.rulesAutosurgery = (function() {
 			if (V.PC.medicine >= 100) slave.health -= 5;
 			else slave.health -= 10;
 
-		} else if ((slave.hears === -1) && (thisSurgery.surgery_smells === 0)) {
+		} else if ((slave.smells === -1) && (thisSurgery.surgery_smells === 0)) {
 			surgeries.push("surgery to correct her sense of smell");
 			slave.smells = 0;
 			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
 			if (V.PC.medicine >= 100) slave.health -= 5;
 			else slave.health -= 10;
 
-		} else if ((slave.hears === 0) && (thisSurgery.surgery_smells === -1)) {
+		} else if ((slave.smells === 0) && (thisSurgery.surgery_smells === -1)) {
 			surgeries.push("surgery to muffle her sense of smell");
 			slave.smells = -1;
 			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
 			if (V.PC.medicine >= 100) slave.health -= 5;
 			else slave.health -= 10;
 
-		} else if ((slave.hears === -1) && (thisSurgery.surgery_tastes === 0)) {
+		} else if ((slave.tastes === -1) && (thisSurgery.surgery_tastes === 0)) {
 			surgeries.push("surgery to correct her sense of taste");
 			slave.tastes = 0;
 			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
 			if (V.PC.medicine >= 100) slave.health -= 5;
 			else slave.health -= 10;
 
-		} else if ((slave.hears === 0) && (thisSurgery.surgery_tastes === -1)) {
+		} else if ((slave.tastes === 0) && (thisSurgery.surgery_tastes === -1)) {
 			surgeries.push("surgery to muffle her sense of taste");
 			slave.tastes = -1;
 			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
@@ -213,24 +213,6 @@ window.rulesAutosurgery = (function() {
 			if (V.PC.medicine >= 100) slave.health -= 5;
 			else slave.health -= 10;
 
-		} else if ((slave.anus > 3) && (thisSurgery.surgery_cosmetic > 0)) {
-			surgeries.push("a restored anus");
-			slave.anus = 3;
-			if (slave.analSkill > 10)
-				slave.analSkill -= 10;
-			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
-			if (V.PC.medicine >= 100) slave.health -= 5;
-			else slave.health -= 10;
-
-		} else if ((slave.vagina > 3) && (thisSurgery.surgery_cosmetic > 0)) {
-			surgeries.push("a restored pussy");
-			slave.vagina = 3;
-			if (slave.vaginalSkill > 10)
-				slave.vaginalSkill -= 10;
-			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
-			if (V.PC.medicine >= 100) slave.health -= 5;
-			else slave.health -= 10;
-
 		} else if ((slave.faceImplant <= 15) && (slave.face <= 95) && (thisSurgery.surgery_cosmetic > 0)) {
 			surgeries.push("a nicer face");
 			if (slave.faceShape === "masculine") slave.faceShape = "androgynous";
@@ -443,25 +425,6 @@ window.rulesAutosurgery = (function() {
 				else slave.health -= 10;
 			}
 
-		} else if ((slave.anus > 0) && (V.surgeryUpgrade === 1) && (thisSurgery.surgery_holes === 2)) {
-			surgeries.push("a virgin anus");
-			slave.anus = 0;
-			if (slave.analSkill > 10) {
-				slave.analSkill -= 10;
-			}
-			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
-			if (V.PC.medicine >= 100) slave.health -= 5;
-			else slave.health -= 10;
-
-		} else if ((slave.vagina > 0) && (V.surgeryUpgrade === 1) && (thisSurgery.surgery_holes === 2)) {
-			surgeries.push("a virgin pussy");
-			slave.vagina = 0;
-			if (slave.vaginalSkill > 10)
-				slave.vaginalSkill -= 10;
-			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
-			if (V.PC.medicine >= 100) slave.health -= 5;
-			else slave.health -= 10;
-
 		} else if ((slave.hips < 2) && (slave.hips < thisSurgery.surgery_hips) && (V.surgeryUpgrade === 1)) {
 			surgeries.push("wider hips");
 			slave.hips++;
@@ -470,26 +433,6 @@ window.rulesAutosurgery = (function() {
 			if (V.PC.medicine >= 100) slave.health -= 5;
 			else slave.health -= 10;
 
-		} else if ((slave.anus > 1) && (thisSurgery.surgery_holes === 1)) {
-			surgeries.push("a tighter anus");
-			slave.anus = 1;
-			if (slave.analSkill > 10) {
-				slave.analSkill -= 10;
-			}
-			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
-			if (V.PC.medicine >= 100) slave.health -= 5;
-			else slave.health -= 10;
-
-		} else if ((slave.vagina > 1) && (thisSurgery.surgery_holes === 1)) {
-			surgeries.push("a tighter pussy");
-			slave.vagina = 1;
-			if (slave.vaginalSkill > 10) {
-				slave.vaginalSkill -= 10;
-			}
-			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
-			if (V.PC.medicine >= 100) slave.health -= 5;
-			else slave.health -= 10;
-
 		} else if ((slave.butt <= 8) && (slave.butt < thisSurgery.surgery_butt)) {
 			if (thisSurgery.surgery_butt !== "no default setting") {
 				surgeries.push("a bigger butt");
@@ -564,6 +507,63 @@ window.rulesAutosurgery = (function() {
 				slave.health -= 10;
 			slave.vasectomy = 0;
 			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
+
+		} else if ((slave.anus > 3) && (thisSurgery.surgery_cosmetic > 0)) {
+			surgeries.push("a restored anus");
+			slave.anus = 3;
+			if (slave.analSkill > 10)
+				slave.analSkill -= 10;
+			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
+			if (V.PC.medicine >= 100) slave.health -= 5;
+			else slave.health -= 10;
+
+		} else if ((slave.vagina > 3) && (thisSurgery.surgery_cosmetic > 0)) {
+			surgeries.push("a restored pussy");
+			slave.vagina = 3;
+			if (slave.vaginalSkill > 10)
+				slave.vaginalSkill -= 10;
+			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
+			if (V.PC.medicine >= 100) slave.health -= 5;
+			else slave.health -= 10;
+
+		} else if ((slave.anus > 0) && (V.surgeryUpgrade === 1) && (thisSurgery.surgery_holes === 2)) {
+			surgeries.push("a virgin anus");
+			slave.anus = 0;
+			if (slave.analSkill > 10) {
+				slave.analSkill -= 10;
+			}
+			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
+			if (V.PC.medicine >= 100) slave.health -= 5;
+			else slave.health -= 10;
+
+		} else if ((slave.vagina > 0) && (V.surgeryUpgrade === 1) && (thisSurgery.surgery_holes === 2)) {
+			surgeries.push("a virgin pussy");
+			slave.vagina = 0;
+			if (slave.vaginalSkill > 10)
+				slave.vaginalSkill -= 10;
+			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
+			if (V.PC.medicine >= 100) slave.health -= 5;
+			else slave.health -= 10;
+
+		} else if ((slave.anus > 1) && (thisSurgery.surgery_holes === 1)) {
+			surgeries.push("a tighter anus");
+			slave.anus = 1;
+			if (slave.analSkill > 10) {
+				slave.analSkill -= 10;
+			}
+			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
+			if (V.PC.medicine >= 100) slave.health -= 5;
+			else slave.health -= 10;
+
+		} else if ((slave.vagina > 1) && (thisSurgery.surgery_holes === 1)) {
+			surgeries.push("a tighter pussy");
+			slave.vagina = 1;
+			if (slave.vaginalSkill > 10) {
+				slave.vaginalSkill -= 10;
+			}
+			cashX(forceNeg(V.surgeryCost), "slaveSurgery", slave);
+			if (V.PC.medicine >= 100) slave.health -= 5;
+			else slave.health -= 10;
 		}
 	}
 
diff --git a/src/js/slaveCostJS.js b/src/js/slaveCostJS.js
index 1339c626047b25e8985575bea6ee7ed7a814d72d..829f261ef3ba828e902d8b9f4e9aab5fef5c2803 100644
--- a/src/js/slaveCostJS.js
+++ b/src/js/slaveCostJS.js
@@ -820,7 +820,7 @@ window.Beauty = (function() {
 		if (slave.preg > slave.pregData.normalBirth/1.33) { /*limited huge boost for full term */
 			beauty += 20;
 		} else if (slave.bellyPreg >= 1500) {
-				beauty += 10;
+			beauty += 10;
 		}
 	}
 
@@ -1597,15 +1597,15 @@ window.FResult = (function() {
 	/** @param {App.Entity.SlaveState} slave */
 	function calcAmputation(slave) {
 		switch(slave.amp) {
-		case 0:
-		case -2:
-		case -5:
-			break;
-		case 1:
-			result -= 2;
-			break;
-		default:
-			result -= 1;
+			case 0:
+			case -2:
+			case -5:
+				break;
+			case 1:
+				result -= 2;
+				break;
+			default:
+				result -= 1;
 		}
 	}
 
diff --git a/src/js/slaveSummaryWidgets.js b/src/js/slaveSummaryWidgets.js
index 2e0dc615c8a4f13451a193048787b6d1af3edbf5..5ec668a67ecb864808852443856f0fefc389679e 100644
--- a/src/js/slaveSummaryWidgets.js
+++ b/src/js/slaveSummaryWidgets.js
@@ -22,12 +22,35 @@ window.SlaveSummary = /** @param {App.Entity.SlaveState} slave */ function Slave
 window.SlaveSummaryUncached = (function(){
 	"use strict";
 	let V, r;
+	/*
+	let pronouns;
+	let he;
+	let him;
+	let his;
+	let hers;
+	let himself;
+	let boy;
+	let He;
+	let His;
+	*/
 
 	/** @param {App.Entity.SlaveState} slave
 	 * @returns {string} */
 	function SlaveSummaryUncached(slave) {
 		V = State.variables;
 		r = "";
+		/*
+		pronouns = getPronouns(slave);
+		he = pronouns.pronoun;
+		him = pronouns.object;
+		his = pronouns.possessive;
+		hers = pronouns.possessivePronoun;
+		himself = pronouns.objectReflexive;
+		boy = pronouns.noun;
+		He = capFirstChar(he);
+		His = capFirstChar(his);
+		*/
+
 		if (V.abbreviateDevotion === 1)
 			short_devotion(slave);
 		else if (V.abbreviateDevotion === 2)
@@ -248,7 +271,7 @@ window.SlaveSummaryUncached = (function(){
 			if (V.abbreviateClothes === 2) {
 				r += `&nbsp;&nbsp;&nbsp;&nbsp;`;
 				if (slave.choosesOwnClothes === 1)
-					r += `Dressing herself.`;
+					r += `Dressing herself. `;
 				long_clothes(slave);
 				long_collar(slave);
 				long_belly(slave);
@@ -4632,6 +4655,9 @@ window.SlaveSummaryUncached = (function(){
 				case "bullet vibrator":
 					r += `Attached bullet vibrator.`;
 					break;
+				case "smart bullet vibrator":
+					r += `Attached smart bullet vibrator.`;
+					break;
 				case "dildo":
 					r += `Vaginal dildo.`;
 					break;
@@ -4669,9 +4695,12 @@ window.SlaveSummaryUncached = (function(){
 			case "sock":
 				r += `Cock sock.`;
 				break;
-			case "vibrator":
+			case "bullet vibrator":
 				r += `Frenulum bullet vibrator.`;
 				break;
+			case "smart bullet vibrator":
+				r += `Smart frenulum bullet vibrator.`;
+				break;
 		}
 		r += " ";
 	}
diff --git a/src/js/storyJS.js b/src/js/storyJS.js
index de8ff5d892421569664fb9086d57938ea466478b..6fac9f460ef408594025b6afe0fd9f2c9f444ca1 100644
--- a/src/js/storyJS.js
+++ b/src/js/storyJS.js
@@ -337,27 +337,27 @@ window.bodyguardSuccessorEligible = /** @param {App.Entity.SlaveState} slave */
 
 window.ngUpdateGenePool = function(genePool) {
 	const transferredSlaveIds = (State.variables.slaves || [])
-	.filter(function(s) { return s.ID >= 1200000; })
-	.map(function(s) { return s.ID - 1200000; });
+		.filter(function(s) { return s.ID >= 1200000; })
+		.map(function(s) { return s.ID - 1200000; });
 	return (genePool || [])
-	.filter(function(s) { return transferredSlaveIds.indexOf(s.ID) >= 0; })
-	.map(function(s) {
-	const result = jQuery.extend(true, {}, s);
-	result.ID += 1200000;
-	return result;
-	});
+		.filter(function(s) { return transferredSlaveIds.indexOf(s.ID) >= 0; })
+		.map(function(s) {
+			const result = jQuery.extend(true, {}, s);
+			result.ID += 1200000;
+			return result;
+		});
 };
 
 window.ngUpdateMissingTable = function(missingTable) {
 	const newTable = {};
 
 	(State.variables.slaves || [])
-	.forEach(s => ([s.pregSource+1200000,s.mother+1200000,s.father+1200000]
-	.filter(i => (i in missingTable))
-	.forEach(i => {
-	newTable[i-1200000] = missingTable[i];
-	newTable[i-1200000].ID -= 1200000;
-	})));
+		.forEach(s => ([s.pregSource+1200000,s.mother+1200000,s.father+1200000]
+			.filter(i => (i in missingTable))
+			.forEach(i => {
+				newTable[i-1200000] = missingTable[i];
+				newTable[i-1200000].ID -= 1200000;
+			})));
 
 	return newTable;
 };
diff --git a/src/js/textbox2.js b/src/js/textbox2.js
index 49939341d27058b2c07faab4e754f6543206dcdf..6d605fa36c20c11d34ac8e3def99aebd91901170 100644
--- a/src/js/textbox2.js
+++ b/src/js/textbox2.js
@@ -14,8 +14,8 @@ Macro.add("textbox2", {
 		var a = this.args[1];
 		var isNumber = typeof(a) === "number";
 		var inputElement = document.createElement("input"),
-		autofocus = false,
-		passage = void 0;
+			autofocus = false,
+			passage = void 0;
 		var setargs = null;
 		if (this.args.length > 3) {
 			passage = this.args[2];
@@ -64,20 +64,20 @@ Macro.add("textbox2", {
 		jQuery(inputElement).attr({
 			id: this.name + "-" + r,
 			name: this.name + "-" + r,
-//			type: isNumber ? "number" : "text", /* TODO - hide spinner if we do this */
+			// type: isNumber ? "number" : "text", /* TODO - hide spinner if we do this */
 			tabindex: 0
 		}).addClass("macro-" + this.name)
-		.on("change", function() {
-			State.setVar(t, valueToNumberIfSame(this.value));
-		}).on("blur", function() {
-			State.setVar(t, valueToNumberIfSame(this.value));
-			if (this.value != a) { // If the value has actually changed, reload the page.  Note != and not !== because types might be different
-				gotoPassage();
-			}
-		})
-		.on("keypress", function(e) {
-			13 === e.which && (e.preventDefault(), State.setVar(t, valueToNumberIfSame(this.value)), gotoPassage())
-		}).appendTo(this.output), State.setVar(t, a), inputElement.value = a, autofocus && (inputElement.setAttribute("autofocus", "autofocus"), postdisplay["#autofocus:" + inputElement.id] = function(e) {
+			.on("change", function() {
+				State.setVar(t, valueToNumberIfSame(this.value));
+			}).on("blur", function() {
+				State.setVar(t, valueToNumberIfSame(this.value));
+				if (this.value != a) { // If the value has actually changed, reload the page.  Note != and not !== because types might be different
+					gotoPassage();
+				}
+			})
+			.on("keypress", function(e) {
+				13 === e.which && (e.preventDefault(), State.setVar(t, valueToNumberIfSame(this.value)), gotoPassage())
+			}).appendTo(this.output), State.setVar(t, a), inputElement.value = a, autofocus && (inputElement.setAttribute("autofocus", "autofocus"), postdisplay["#autofocus:" + inputElement.id] = function(e) {
 			delete postdisplay[e], setTimeout(function() {
 				return inputElement.focus()
 			}, Engine.minDomActionDelay)
diff --git a/src/js/textboxJS.js b/src/js/textboxJS.js
index e4917d08c542242f60ab649b681be3889da9901b..d0798dbd0c6c486764a2a1a31904d9e40713e233 100644
--- a/src/js/textboxJS.js
+++ b/src/js/textboxJS.js
@@ -3,12 +3,12 @@
 window.setReplaceTextboxMaxLength = function (storyVarName, maxLength) {
 	var textboxId = '#textbox-' + Util.slugify(storyVarName);
 	$(textboxId)
-			.attr('maxlength', maxLength)
-			.css({
-				'min-width' : 'initial',
-				width : maxLength + 'em',
-				padding : '3px 2px'
-			});
+		.attr('maxlength', maxLength)
+		.css({
+			'min-width' : 'initial',
+			width : maxLength + 'em',
+			padding : '3px 2px'
+		});
 };
 
 /* Nicked off TheMadExile, works for non-replace textboxes */
diff --git a/src/js/utilJS.js b/src/js/utilJS.js
index e3cb2928bb36e496705724e1c64fa623e26a52ee..36adc911a34a79e9aeb364f3fe6c2681eb915063 100644
--- a/src/js/utilJS.js
+++ b/src/js/utilJS.js
@@ -413,29 +413,6 @@ window.gaussianPair = function() {
 	return [r * Math.cos(sigma), r * Math.sin(sigma)];
 };
 
-if (!Array.prototype.findIndex) {
-	Array.prototype.findIndex = function(predicate) {
-		if (this == null) {
-			throw new TypeError('Array.prototype.find called on null or undefined');
-		}
-		if (typeof predicate !== 'function') {
-			throw new TypeError('predicate must be a function');
-		}
-		let list = Object(this);
-		let length = list.length >>> 0;
-		let thisArg = arguments[1];
-		let value;
-
-		for (let i = 0; i < length; i++) {
-			value = list[i];
-			if (predicate.call(thisArg, value, i, list)) {
-				return i;
-			}
-		}
-		return -1;
-	};
-}
-
 /*
 A categorizer is used to "slice" a value range into distinct categories in an efficient manner.
 
@@ -623,7 +600,11 @@ window.cashFormat = function(s) {
 	if (!s) {
 		s = 0;
 	}
-	return `¤${ num(s)}`;
+	if (s > 0) {
+		return `¤${ num(s)}`;
+	} else {
+		return `¤${s}`;
+	}
 };
 
 window.repFormat = function(s) {
@@ -736,11 +717,7 @@ window.budgetLine = function(category, title) {
 };
 
 window.isFloat = function(n) {
-	return n === +n && n !== (n|0);
-};
-
-window.isInt = function(n) {
-	return n === +n && n === (n|0);
+	return Number.isFinite(n) && Math.floor(n) !== n;
 };
 
 window.jsRandom = function(min, max) {
@@ -1511,8 +1488,20 @@ window.resyncSlaveToAge = function(slave) {
 		slave.boobs = 200;
 		slave.birthWeek = 0;
 		SetBellySize(slave);
+		if (slave.dick > 0) {
+			slave.dick = 1;
+		}
+		if (slave.balls > 0) {
+			slave.balls = 1;
+		}
 	} else {
 		slave.boobs = Math.max(slave.boobs, 500);
+		if (slave.dick > 2) {
+			slave.dick = 2;
+		}
+		if (slave.balls > 2) {
+			slave.balls = 2;
+		}
 	}
 	slave.career = randomCareer(slave);
 }
diff --git a/src/js/wombJS.js b/src/js/wombJS.js
index 4d2eea75c4db3da11132933c0865661fce0c1619..af9057a22e1a663214d6ee2b5cf0cd44e156d530 100644
--- a/src/js/wombJS.js
+++ b/src/js/wombJS.js
@@ -628,13 +628,13 @@ window.FetusGlobalReserveCount = function(reserveType)
 		slave.womb.forEach(function(ft){
 			if (ft.reserve === reserveType)
 				cnt++;
-			});
 		});
+	});
 
 	SV.PC.womb.forEach(function(ft){
 		if (ft.reserve === reserveType)
 			cnt++;
-		});
+	});
 
 	return cnt;
 };
diff --git a/src/npc/startingGirls/commitStartingGirl.tw b/src/npc/startingGirls/commitStartingGirl.tw
index 6deb35a22812960596b2b01aab1b4eeb025c19ef..341a9aad22af758fb92365b7172e427cbbbbb3cc 100644
--- a/src/npc/startingGirls/commitStartingGirl.tw
+++ b/src/npc/startingGirls/commitStartingGirl.tw
@@ -65,13 +65,13 @@
 				//This slave already has a mother.//
 			<</if>>
 			<<if $seeDicks>>
-			<<if $activeSlave.father <= 0>>
-				<br>&nbsp;&nbsp;&nbsp;&nbsp;
-				[[Dick-mother|RG AS Dump][$returnTo = "Starting Girls", $activeSlave.father = $IDNumber, $startingGirlRelation = "dickdaughter", $startingGirlCopied = 1]]
-				//A slave who provided the impregnation to create $activeSlave.slaveName.//
-			<<else>>
-				//This slave already has a dick-mother.//
-			<</if>>
+				<<if $activeSlave.father <= 0>>
+					<br>&nbsp;&nbsp;&nbsp;&nbsp;
+					[[Dick-mother|RG AS Dump][$returnTo = "Starting Girls", $activeSlave.father = $IDNumber, $startingGirlRelation = "dickdaughter", $startingGirlCopied = 1]]
+					//A slave who provided the impregnation to create $activeSlave.slaveName.//
+				<<else>>
+					//This slave already has a dick-mother.//
+				<</if>>
 			<</if>>
 		<</if>>
 		<<if $activeSlave.actualAge < 44>>
diff --git a/src/npc/startingGirls/startingGirls.tw b/src/npc/startingGirls/startingGirls.tw
index c95cf083c73cae40f2ee5ce6b514a17f2de67055..0ac3709b9d0eb01c14332d2ea026f881d245aace 100644
--- a/src/npc/startingGirls/startingGirls.tw
+++ b/src/npc/startingGirls/startingGirls.tw
@@ -555,9 +555,9 @@ __You are customizing this slave:__
 
 <<options $activeSlave.genes>>
 	''Genes:''
-	<<option "XX" "XX" "$activeSlave.dick = 0, $activeSlave.balls = 0,$activeSlave.clit = 0,$activeSlave.pubertyXY = 0,$activeSlave.pubertyAgeXY = $potencyAge, $activeSlave.pubertyXX=($activeSlave.pubertyAgeXX<$activeSlave.actualAge?1:0),$activeSlave.vagina=Math.max(0, $activeSlave.vagina),$activeSlave.boobs=Math.max(500,$activeSlave.boobs),  $activeSlave.balls=0, $activeSlave.scrotum=0, $activeSlave.prostate=0,$activeSlave.shoulders=either(-2,-1,0),$activeSlave.hips=either(-2,-1,0)">>
+	<<option "XX" "XX" "$activeSlave.dick = 0, $activeSlave.balls = 0, $activeSlave.clit = 0, $activeSlave.pubertyXY = 0, $activeSlave.pubertyAgeXY = $potencyAge, $activeSlave.pubertyXX = ($activeSlave.pubertyAgeXX < $activeSlave.actualAge ? 1 : 0), $activeSlave.vagina = Math.max(0, $activeSlave.vagina), $activeSlave.boobs = Math.max(500, $activeSlave.boobs),  $activeSlave.balls = 0, $activeSlave.scrotum = 0, $activeSlave.prostate = 0, $activeSlave.shoulders = either(-2,-1,0), $activeSlave.hips = either(-2,-1,0)">>
 		@@.yellow;XX@@ (Female)
-	<<option "XY" "XY" "$activeSlave.dick = 3, $activeSlave.vagina=-1, $activeSlave.preg = 0, WombFlush($activeSlave), $activeSlave.belly = 0,$activeSlave.bellyPreg = 0,$activeSlave.pubertyXY=($activeSlave.pubertyAgeXY<$activeSlave.actualAge?1:0), $activeSlave.pregType = 0, $activeSlave.pregSource = 0, $activeSlave.pregWeek = 0, $activeSlave.pregKnown = 0,$activeSlave.pubertyXX = 0,$activeSlave.pubertyAgeXX = $fertilityAge, $activeSlave.ovaries = 0, $activeSlave.boobs=0, $activeSlave.balls=3, $activeSlave.scrotum=3, $activeSlave.prostate=1,$activeSlave.shoulders=either(0,1,2),$activeSlave.hips=either(0,1,2)">>
+	<<option "XY" "XY" "$activeSlave.dick = 3, $activeSlave.vagina = -1, $activeSlave.preg = 0, WombFlush($activeSlave), $activeSlave.belly = 0, $activeSlave.bellyPreg = 0, $activeSlave.pubertyXY = ($activeSlave.pubertyAgeXY < $activeSlave.actualAge ? 1 : 0), $activeSlave.pregType = 0, $activeSlave.pregSource = 0, $activeSlave.pregWeek = 0, $activeSlave.pregKnown = 0, $activeSlave.pubertyXX = 0, $activeSlave.pubertyAgeXX = $fertilityAge, $activeSlave.ovaries = 0, $activeSlave.boobs = 0, $activeSlave.balls = 3, $activeSlave.scrotum = 3, $activeSlave.prostate = 1, $activeSlave.shoulders = either(0,1,2), $activeSlave.hips = either(0,1,2)">>
 		@@.yellow;XY@@ (Male)
 <</options>>
 
@@ -716,18 +716,18 @@ __You are customizing this slave:__
 	<br>
 	<<options $activeSlave.race>>
 		''Ethnicity:'' $activeSlave.race
-		<<option "white"             "White">>
-		<<option "black"             "Black">>
-		<<option "latina"            "Latina">>
-		<<option "asian"             "Asian">>
-		<<option "middle eastern"    "Middle Eastern">>
-		<<option "amerindian"        "Amerindian">>
+		<<option "white"			 "White">>
+		<<option "black"			 "Black">>
+		<<option "latina"			"Latina">>
+		<<option "asian"			 "Asian">>
+		<<option "middle eastern"	"Middle Eastern">>
+		<<option "amerindian"		"Amerindian">>
 		<<option "southern european" "Southern European">>
-		<<option "semitic"           "Semitic">>
-		<<option "malay"             "Malay">>
-		<<option "indo-aryan"        "Indo-Aryan">>
+		<<option "semitic"		   "Semitic">>
+		<<option "malay"			 "Malay">>
+		<<option "indo-aryan"		"Indo-Aryan">>
 		<<option "pacific islander"  "Pacific Islander">>
-		<<option "mixed race"        "Mixed Race">>
+		<<option "mixed race"		"Mixed Race">>
 		<<option>>
 			<<textbox2 "$activeSlave.race" $activeSlave.race "Starting Girls">>
 	<</options>>
@@ -736,28 +736,28 @@ __You are customizing this slave:__
 <br>
 <<options $activeSlave.skin>>
 	''Skin color:'' $activeSlave.skin
-	<<option "pure white"     "Pure White">>
+	<<option "pure white"	 "Pure White">>
 	<<option "extremely pale" "Extremely Pale">>
-	<<option "pale"           "Pale">>
+	<<option "pale"		   "Pale">>
 	<<option "extremely fair" "Extremely Fair">>
-	<<option "very fair"      "Very Fair">>
-	<<option "fair"           "Fair">>
-	<<option "white"          "White">>
-	<<option "light"          "Light">>
-	<<option "lightened"      "Lightened">>
-	<<option "light olive"    "Light Olive">>
-	<<option "olive"          "Olive">>
-	<<option "natural"        "Natural">>
-	<<option "tanned"         "Tanned">>
-	<<option "bronzed"        "Bronzed">>
-	<<option "dark olive"     "Dark Olive">>
-	<<option "dark"           "Dark">>
-	<<option "light brown"    "Light Brown">>
-	<<option "brown"          "Brown">>
-	<<option "dark brown"     "Dark Brown">>
-	<<option "black"          "Black">>
-	<<option "ebony"          "Ebony">>
-	<<option "pure black"     "Pure Black">>
+	<<option "very fair"	  "Very Fair">>
+	<<option "fair"		   "Fair">>
+	<<option "white"		  "White">>
+	<<option "light"		  "Light">>
+	<<option "lightened"	  "Lightened">>
+	<<option "light olive"	"Light Olive">>
+	<<option "olive"		  "Olive">>
+	<<option "natural"		"Natural">>
+	<<option "tanned"		 "Tanned">>
+	<<option "bronzed"		"Bronzed">>
+	<<option "dark olive"	 "Dark Olive">>
+	<<option "dark"		   "Dark">>
+	<<option "light brown"	"Light Brown">>
+	<<option "brown"		  "Brown">>
+	<<option "dark brown"	 "Dark Brown">>
+	<<option "black"		  "Black">>
+	<<option "ebony"		  "Ebony">>
+	<<option "pure black"	 "Pure Black">>
 	<<option>>
 		<<textbox2 "$activeSlave.skin" $activeSlave.skin "Starting Girls">>
 <</options>>
@@ -894,7 +894,7 @@ __You are customizing this slave:__
 	<</options>>
 
 	<br>
-	<<options >>
+	<<options $activeSlave.tastes>>
 		''Taste ability:''
 		<<option 0 "Normal">> Normal.
 		<<option -1 "None">> Unable to taste.
@@ -902,14 +902,17 @@ __You are customizing this slave:__
 <</if>>
 <br>
 <br>
+
 <<options $activeSlave.boobs>>
 	''Breasts:''
-	<<optionlte 200 200 "Flat">>  Flat.
-	<<optionlte 500 500 "Healthy">>  Healthy.
-	<<optionlte 800 800 "Large">>  Large.
-	<<optionlte 1200 1200 "Very Large">>  Very Large.
-	<<optionlte 2000 2000 "Huge">>  Huge.
-	<<optionlte 4000 4000 "Massive">>  Massive.
+	<<optionlte 200 200 "Flat">>  Flat (AA-cup).
+	<<optionlte 300 300 "Small">>  Small (A-cup).
+	<<optionlte 400 400 "Medium">>  Medium (B-cup).
+	<<optionlte 500 500 "Healthy">>  Healthy (C-cup).
+	<<optionlte 800 800 "Large">>  Large (DD-cup).
+	<<optionlte 1200 1200 "Very Large">>  Very Large (G-cup).
+	<<optionlte 2050 2050 "Huge">>  Huge (K-cup).
+	<<optionlte 3950 3950 "Massive">>  Massive (Q-cup).
 	<<optionlte 6000 6000 "Monstrous">>  Monstrous.
 	<<optiondefault 8000 "Science experiment">>Science experiment.
 	<<option>>
@@ -927,11 +930,11 @@ __You are customizing this slave:__
 <br>
 <<options $activeSlave.nipples>>
 	''Nipples:'' $activeSlave.nipples
-	<<option "tiny"     "Tiny">>
-	<<option "cute"     "Cute">>
-	<<option "puffy"    "Puffy">>
+	<<option "tiny"	 "Tiny">>
+	<<option "cute"	 "Cute">>
+	<<option "puffy"	"Puffy">>
 	<<option "inverted" "Inverted">>
-	<<option "huge"     "Huge">>
+	<<option "huge"	 "Huge">>
 <</options>>
 
 <<options $activeSlave.areolae>>
@@ -1192,7 +1195,7 @@ __You are customizing this slave:__
 			//Must have a vagina to have vaginal skills//
 	<</options>>
 <<else>>
-	<<options $activeSlave.vagina>>
+	<<options $activeSlave.vaginalSkill>>
 		''Vaginal sex:''
 		<<optionlte 10 0  "Unskilled">>Unskilled.
 		<<optionlte 30 15 "Basic">>@@.cyan;Basic.@@
@@ -1284,16 +1287,16 @@ __You are customizing this slave:__
 				<<else>>
 					@@.lightcoral;$activeSlave.fetish.@@
 				<</if>>
-			<<option ""            "Unknown" "$activeSlave.fetish=either('boobs', 'buttslut', 'cumslut', 'dom', 'humiliation', 'masochist', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'pregnancy', 'sadist', 'submissive'),$activeSlave.fetishKnown=0">>
-			<<option "none"        "None">>
+			<<option ""			"Unknown" "$activeSlave.fetish=either('boobs', 'buttslut', 'cumslut', 'dom', 'humiliation', 'masochist', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'pregnancy', 'sadist', 'submissive'),$activeSlave.fetishKnown=0">>
+			<<option "none"		"None">>
 			<<option "submissive"  "Sub">>
-			<<option "dom"         "Dom">>
-			<<option "cumslut"     "Cumslut">>
+			<<option "dom"		 "Dom">>
+			<<option "cumslut"	 "Cumslut">>
 			<<option "humiliation" "Humiliation">>
-			<<option "buttslut"    "Buttslut">>
-			<<option "boobs"       "Breasts">>
+			<<option "buttslut"	"Buttslut">>
+			<<option "boobs"	   "Breasts">>
 			<<option "pregnancy"   "Pregnancy">>
-			<<option "sadist"      "Sadism">>
+			<<option "sadist"	  "Sadism">>
 			<<option "masochist"   "Masochism">>
 		<</options>>
 	<<else>>
@@ -1304,16 +1307,16 @@ __You are customizing this slave:__
 				<<else>>
 					@@.lightcoral;$activeSlave.fetish.@@
 				<</if>>
-			<<option ""            "Unknown" "$activeSlave.fetish=either('boobs', 'buttslut', 'cumslut', 'dom', 'humiliation', 'masochist', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'pregnancy', 'sadist', 'submissive'),$activeSlave.fetishKnown=0">>
-			<<option "none"        "None">>
+			<<option ""			"Unknown" "$activeSlave.fetish=either('boobs', 'buttslut', 'cumslut', 'dom', 'humiliation', 'masochist', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'none', 'pregnancy', 'sadist', 'submissive'),$activeSlave.fetishKnown=0">>
+			<<option "none"		"None">>
 			<<option "submissive"  "Sub">>
-			<<option "dom"         "Dom">>
-			<<option "cumslut"     "Cumslut">>
+			<<option "dom"		 "Dom">>
+			<<option "cumslut"	 "Cumslut">>
 			<<option "humiliation" "Humiliation">>
-			<<option "buttslut"    "Buttslut">>
-			<<option "boobs"       "Breasts">>
+			<<option "buttslut"	"Buttslut">>
+			<<option "boobs"	   "Breasts">>
 			<<option "pregnancy"   "Pregnancy">>
-			<<option "sadist"      "Sadism">>
+			<<option "sadist"	  "Sadism">>
 			<<option "masochist"   "Masochism">>
 			<<option "mindbroken"  "Mindbroken" "$activeSlave.sexualFlaw = 'none', $activeSlave.behavioralFlaw = 'none', $activeSlave.sexualQuirk = 'none', $activeSlave.sexualFlaw = 'none'">>
 		<</options>>
@@ -1432,15 +1435,15 @@ __You are customizing this slave:__
 		<<else>>
 			@@.red;$activeSlave.behavioralFlaw.@@
 		<</if>>
-	<<option "none"        "None">>
-	<<option "arrogant"    "Arrogant">>
-	<<option "bitchy"      "Bitchy">>
-	<<option "odd"         "Odd">>
+	<<option "none"		"None">>
+	<<option "arrogant"	"Arrogant">>
+	<<option "bitchy"	  "Bitchy">>
+	<<option "odd"		 "Odd">>
 	<<option "hates men"   "Men">>
 	<<option "hates women" "Women">>
-	<<option "anorexic"    "Anorexic">>
+	<<option "anorexic"	"Anorexic">>
 	<<option "gluttonous"  "Gluttonous">>
-	<<option "devout"      "Devout">>
+	<<option "devout"	  "Devout">>
 	<<option "liberated"   "Liberated">>
 <</options>>
 <br>
@@ -1451,16 +1454,16 @@ __You are customizing this slave:__
 		<<else>>
 			@@.green;$activeSlave.behavioralQuirk.@@
 		<</if>>
-	<<option "none"         "None" >>
-	<<option "confident"    "Confident" >>
-	<<option "cutting"      "Cutting" >>
-	<<option "funny"        "Funny" >>
+	<<option "none"		 "None" >>
+	<<option "confident"	"Confident" >>
+	<<option "cutting"	  "Cutting" >>
+	<<option "funny"		"Funny" >>
 	<<option "adores men"   "Men" >>
 	<<option "adores women" "Women" >>
-	<<option "insecure"     "Insecure" >>
-	<<option "fitness"      "Fitness" >>
-	<<option "sinful"       "Sinful" >>
-	<<option "advocate"     "Advocate" >>
+	<<option "insecure"	 "Insecure" >>
+	<<option "fitness"	  "Fitness" >>
+	<<option "sinful"	   "Sinful" >>
+	<<option "advocate"	 "Advocate" >>
 <</options>>
 <br>
 <<options $activeSlave.sexualFlaw>>
@@ -1608,20 +1611,20 @@ __You are customizing this slave:__
 <</link>>
 //Inexpensive potential to become a great right hand woman//
 <<if $seeExtreme != 0>>
-<br>&nbsp;&nbsp;&nbsp;&nbsp;
-<<link "Wellspring">>
-	<<StartingGirlsWorkaround>>
-	<<set $activeSlave.analSkill = 0, $activeSlave.oralSkill = 0, $activeSlave.vaginalSkill = 0, $activeSlave.whoreSkill = 0, $activeSlave.entertainSkill = 0, $activeSlave.combatSkill = 0, $activeSlave.actualAge = 18, $activeSlave.visualAge = 18, $activeSlave.physicalAge = 18, $activeSlave.fetishKnown = 0, $activeSlave.attrKnown = 0, $activeSlave.health = 10, $activeSlave.intelligence = -100, $activeSlave.intelligenceImplant = 0, $activeSlave.vagina = 3, $activeSlave.anus = 3, $activeSlave.ovaries = 1, $activeSlave.dick = 5, $activeSlave.balls = 5, $activeSlave.prostate = 1, $activeSlave.lactation = 2, $activeSlave.lactationDuration = 2, $activeSlave.nipples = "huge", $activeSlave.boobs = 10000>>
-	<<goto "Starting Girls">>
-<</link>>
-//Capable of producing all kinds of useful fluids//
-<br>&nbsp;&nbsp;&nbsp;&nbsp;
-<<link "Onahole">>
-	<<StartingGirlsWorkaround>>
-	<<set $activeSlave.analSkill = 0, $activeSlave.oralSkill = 0, $activeSlave.vaginalSkill = 0, $activeSlave.whoreSkill = 0, $activeSlave.entertainSkill = 0, $activeSlave.combatSkill = 0, $activeSlave.fetish = "mindbroken", $activeSlave.amp = 1, $activeSlave.voice = 0, $activeSlave.eyes = 1, $activeSlave.hears = 0>>
-	<<goto "Starting Girls">>
-<</link>>
-//A living cocksleeve//
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;
+	<<link "Wellspring">>
+		<<StartingGirlsWorkaround>>
+		<<set $activeSlave.analSkill = 0, $activeSlave.oralSkill = 0, $activeSlave.vaginalSkill = 0, $activeSlave.whoreSkill = 0, $activeSlave.entertainSkill = 0, $activeSlave.combatSkill = 0, $activeSlave.actualAge = 18, $activeSlave.visualAge = 18, $activeSlave.physicalAge = 18, $activeSlave.fetishKnown = 0, $activeSlave.attrKnown = 0, $activeSlave.health = 10, $activeSlave.intelligence = -100, $activeSlave.intelligenceImplant = 0, $activeSlave.vagina = 3, $activeSlave.anus = 3, $activeSlave.ovaries = 1, $activeSlave.dick = 5, $activeSlave.balls = 5, $activeSlave.prostate = 1, $activeSlave.lactation = 2, $activeSlave.lactationDuration = 2, $activeSlave.nipples = "huge", $activeSlave.boobs = 10000>>
+		<<goto "Starting Girls">>
+	<</link>>
+	//Capable of producing all kinds of useful fluids//
+	<br>&nbsp;&nbsp;&nbsp;&nbsp;
+	<<link "Onahole">>
+		<<StartingGirlsWorkaround>>
+		<<set $activeSlave.analSkill = 0, $activeSlave.oralSkill = 0, $activeSlave.vaginalSkill = 0, $activeSlave.whoreSkill = 0, $activeSlave.entertainSkill = 0, $activeSlave.combatSkill = 0, $activeSlave.fetish = "mindbroken", $activeSlave.amp = 1, $activeSlave.voice = 0, $activeSlave.eyes = 1, $activeSlave.hears = 0>>
+		<<goto "Starting Girls">>
+	<</link>>
+	//A living cocksleeve//
 <</if>>
 
 <br><br>__Start over by selecting a nationality:__
@@ -1638,7 +1641,7 @@ __You are customizing this slave:__
 	<</link>>
 	">>
 	<<if _sg < setup.baseNationalities.length-1>>
-	|
+		|
 	<</if>>
 <</for>>
 
diff --git a/src/pregmod/csec.tw b/src/pregmod/csec.tw
index c36faeb356f693fa047670fa8946efa9b4bc5b29..fa303a024ed9cd634df1e616b998d0ae460ec64e 100644
--- a/src/pregmod/csec.tw
+++ b/src/pregmod/csec.tw
@@ -418,7 +418,7 @@ Performing a cesarean section is trivial for the remote surgery to carry out. $a
 							For a moment, $he saw a glimmer of good in you; @@.mediumorchid;$he was clearly wrong.@@ $His mind struggles to comprehend @@.gold;why $he could ever even thing of trusting such a person.@@
 							<<set $activeSlave.trust -= 30, $activeSlave.devotion -= 30>>
 						<</if>>
-						<<set $cash += _curBabies*(50+_babyCost)>>
+						<<run cashX(_curBabies*(50+_babyCost), "babyTransfer")>>
 				<</switch>>
 	<<else>>
 		<<set $nextButton = "Back">><<UpdateNextButton>> /* unlock Continue button */
diff --git a/src/pregmod/saClothes.tw b/src/pregmod/saClothes.tw
index 0a1dff8fdd22a8a40607fb0f299d45280496ebcc..83637c6589e568280078daf806299c300cb2c130 100644
--- a/src/pregmod/saClothes.tw
+++ b/src/pregmod/saClothes.tw
@@ -616,7 +616,7 @@
 	<<else>>
 		<<if ($slaves[$i].heels == 1) && !canWalk($slaves[$i]) && ($slaves[$i].fetish != "mindbroken")>>
 			<<if $slaves[$i].shoes == "pumps">>
-				While $he can barely stand with $his heeled pumps, $he is incapable of taking a step in them.
+				While $he can just barely stand with $his heeled pumps, $he is incapable of taking a step in them.
 			<</if>>
 			<<if ($slaves[$i].devotion >= -20) && ($slaves[$i].fetish == "submissive") && ($slaves[$i].fetishKnown == 1)>>
 				$He @@.hotpink;loves being forced@@ to crawl around like some kind of animal.
@@ -639,8 +639,15 @@
 <</if>>
 
 <<if ($slaves[$i].vaginalAccessory != "none")>>
-	<<if ($slaves[$i].vaginalAttachment == "bullet vibrator")>>
-		/* TODO: add effects here */
+	<<if ($slaves[$i].vaginalAttachment == "bullet vibrator" || $slaves[$i].vaginalAttachment == "smart bullet vibrator")>>
+		Constantly wearing a bullet vibrator
+		<<if $slaves[$i].devotion < 20>>
+			habituates $him to sexual slavery and @@pink;increases $his submissiveness.@@
+			<<set $slaves[$i].devotion += 2>>
+		<<else>>
+			reminds $him of $his place and @@.pink;increases $his devotion to you.@@
+			<<set $slaves[$i].devotion++>>
+		<</if>>
 	<<elseif ($slaves[$i].vaginalAccessory == "dildo")>>
 		<<if ($slaves[$i].vagina < 1) && (random(1,100) > 50)>>
 			Constantly wearing a dildo in $his virgin pussy @@.lime;gets it used to penetration.@@
diff --git a/src/pregmod/widgets/seBirthWidgets.tw b/src/pregmod/widgets/seBirthWidgets.tw
index 1200196434bf731e3d6887af9ad57cdd93ef29dc..76cfb114020445baff089da27d85db9d5afb55c0 100644
--- a/src/pregmod/widgets/seBirthWidgets.tw
+++ b/src/pregmod/widgets/seBirthWidgets.tw
@@ -1051,7 +1051,8 @@ All in all,
 							For a moment, $he saw a glimmer of good in you; @@.mediumorchid;$he was clearly wrong.@@ $His mind struggles to comprehend @@.gold;why $he could ever even think of trusting such a person.@@
 							<<set $slaves[$i].trust -= 30, $slaves[$i].devotion -= 30>>
 						<</if>>
-						<<set $cash += _curBabies*(50+_babyCost), $slaveOrphanageTotal -= _count>>
+						<<set $slaveOrphanageTotal -= _count>>
+						<<run cashX(_curBabies*(50+_babyCost), "babyTransfer")>>
 					<</replace>>
 				<</link>>
 			<<else>>
@@ -1072,7 +1073,8 @@ All in all,
 							For a moment, $he saw a glimmer of good in you; @@.mediumorchid;$he was clearly wrong.@@ $His mind struggles to comprehend @@.gold;why $he could ever even think of trusting such a person.@@
 							<<set $slaves[$i].trust -= 30, $slaves[$i].devotion -= 30>>
 						<</if>>
-						<<set $cash += _curBabies*(50+_babyCost), $slaveOrphanageTotal -= _count>>
+						<<set $slaveOrphanageTotal -= _count>>
+						<<run cashX(_curBabies*(50+_babyCost), "babyTransfer")>>
 					<</replace>>
 				<</link>>
 			<</if>>
diff --git a/src/uncategorized/BackwardsCompatibility.tw b/src/uncategorized/BackwardsCompatibility.tw
index 35e6d589d50ae2bb2ac66b42e9c8f10ae5107529..f109f21dcacaac44fee2dd98694713b229de5152 100644
--- a/src/uncategorized/BackwardsCompatibility.tw
+++ b/src/uncategorized/BackwardsCompatibility.tw
@@ -461,6 +461,9 @@
 <<if ndef $toysBoughtButtPlugTails>>
 	<<set $toysBoughtButtPlugTails = 0>>
 <</if>>
+<<if ndef $toysBoughtSmartVibes>>
+	<<set $toysBoughtSmartVibes = 0>>
+<</if>>
 <<if ndef $buckets>>
 	<<set $buckets = 0>>
 <</if>>
diff --git a/src/uncategorized/REFI.tw b/src/uncategorized/REFI.tw
index 9b2e23285cb3b64108282fa5b5cb9f7768b03617..65b1a811e5f7509a072cdb86ce5f0332ec5e2a6f 100644
--- a/src/uncategorized/REFI.tw
+++ b/src/uncategorized/REFI.tw
@@ -62,7 +62,7 @@
 	<<case "dom">>
 		/* TODO: expand this */
 		<<set $activeSlave = getSlave($dominantInterestTargetID)>>
-		<<set _refi = $slaveIndices[$dominantID]>>
+		<<set _refi = $slaveIndices[$domID]>>
 	<<case "submissive">>
 		<<set $activeSlave = getSlave($submissiveInterestTargetID)>>
 		<<set _refi = $slaveIndices[$subID]>>
diff --git a/src/uncategorized/arcmgmt.tw b/src/uncategorized/arcmgmt.tw
index 0013f17583c9afb0a24c8e4909eec38fbec43c28..f6bce3e54467d37bb95fb52f288d5b488229062f 100644
--- a/src/uncategorized/arcmgmt.tw
+++ b/src/uncategorized/arcmgmt.tw
@@ -1079,7 +1079,7 @@ _percTopClass = Math.trunc(($topClass / ($ACitizens + $ASlaves)) * 1000) / 10>>
 	Those of your citizens who have not yet subscribed to the society you are building are permitted to live and do business here, but must pay a moderate jizya tax for the privilege as part of their rent.
 <</if>>
 <<set _rents = Math.trunc(($lowerClass * $LCRent + $middleClass * $MCRent + $upperClass * $UCRent + $topClass * $TCRent) * _rentMultiplier / 25)>>
-<<if !isInt(_rents)>>
+<<if !Number.isInteger(_rents)>>
 	<br>@@.red;Error: rents is outside accepted range, please report this issue@@
 <<else>>
 	<<run cashX(_rents, "rents")>>
diff --git a/src/uncategorized/bodyModification.tw b/src/uncategorized/bodyModification.tw
index 3ebc6ef2d386beeaa971a5f3dbd83ba6b949a705..9e77734b1200cdcdca3e954ff67859c5820c5f60 100644
--- a/src/uncategorized/bodyModification.tw
+++ b/src/uncategorized/bodyModification.tw
@@ -395,7 +395,7 @@ Choose piercing style:
 		<<if $activeSlave.lipsPiercing != 1>><<set $activeSlave.lipsPiercing = 1>>				<<run cashX(forceNeg($modCost), "slaveMod", $activeSlave)>><</if>>
 		<<if $activeSlave.tonguePiercing != 1>><<set $activeSlave.tonguePiercing = 1>>			<<run cashX(forceNeg($modCost), "slaveMod", $activeSlave)>><</if>>
 		<<if $activeSlave.nipples != "fuckable">>
-			<<if $activeSlave.nipplesPiercing != 1 && >><<set $activeSlave.nipplesPiercing = 1>><<run cashX(forceNeg($modCost), "slaveMod", $activeSlave)>><</if>>
+			<<if $activeSlave.nipplesPiercing != 1>><<set $activeSlave.nipplesPiercing = 1>><<run cashX(forceNeg($modCost), "slaveMod", $activeSlave)>><</if>>
 		<</if>>
 		<<if $activeSlave.areolaePiercing != 1>><<set $activeSlave.areolaePiercing = 1>>		<<run cashX(forceNeg($modCost), "slaveMod", $activeSlave)>><</if>>
 		<<if $activeSlave.corsetPiercing != 1>><<set $activeSlave.corsetPiercing = 1>>			<<run cashX(forceNeg($modCost), "slaveMod", $activeSlave)>><</if>>
diff --git a/src/uncategorized/costsBudget.tw b/src/uncategorized/costsBudget.tw
index 329ed2cd00b98e4c237e79eed28274f96972a4e5..564e1f4ca8643ad9ed5dc70012426d9a5ec83507 100644
--- a/src/uncategorized/costsBudget.tw
+++ b/src/uncategorized/costsBudget.tw
@@ -11,7 +11,7 @@
 
 //Here you can view many of the financial details of your arcology, <<= properTitle()>>. The detailed list of slaves and their costs (food, hormones) that you may remember can now be found in the "Slave maintenance" link. Other links will allow you to directly control areas of your arcology to adjust spending to suit your tastes.//
 
-<br style="clear:both" /><<if $lineSeparations == 0>><br><<else>><hr style="margin:0"><</if>>
+<br style="clear:both"><<if $lineSeparations == 0>><br><<else>><hr style="margin:0"><</if>>
 
 <<if $difficultySwitch == 1>>
 	//The Local Economy score effects some prices in your ecology. The lower the score, the higher the prices. The base score is ''100''.//
@@ -59,7 +59,7 @@
 		<<set _econPercent = Math.trunc(100000/$localEcon-1000)/10>>
 		increasing prices by @@.red;''<<print _econPercent>>%.''@@
 	<</if>>
-	<br style="clear:both" /><<if $lineSeparations == 0>><br><br><<else>><hr style="margin:0"><</if>>
+	<br style="clear:both"><<if $lineSeparations == 0>><br><br><<else>><hr style="margin:0"><</if>>
 <</if>>
 
 //Your weekly costs are as follows://
diff --git a/src/uncategorized/dairyReport.tw b/src/uncategorized/dairyReport.tw
index 551513703c5d7df8906d4053eb0fbf7108c63ecd..c66e64ef586510f0092a2b552096c507da5d5c2d 100644
--- a/src/uncategorized/dairyReport.tw
+++ b/src/uncategorized/dairyReport.tw
@@ -458,7 +458,7 @@
 		<<run cashX(forceNeg($surgeryCost), "slaveSurgery", $slaves[$i])>>
 	<</if>>
 	<<if $slaves[$i].vasectomy == 1>>
-		<<set $slaves[$i].vasectomy = 0, $slaves[$i].health -= 10,>>
+		<<set $slaves[$i].vasectomy = 0, $slaves[$i].health -= 10>>
 		<<run cashX(forceNeg($surgeryCost), "slaveSurgery", $slaves[$i])>>
 	<</if>>
 	<<if ($dairySlimMaintain == 0)>>
diff --git a/src/uncategorized/endWeek.tw b/src/uncategorized/endWeek.tw
index c208ce983b8650da9bc9f6542e85d7096002c62e..c6909755b9a052142dc52a5af79182b0e6337f27 100644
--- a/src/uncategorized/endWeek.tw
+++ b/src/uncategorized/endWeek.tw
@@ -1,10 +1,5 @@
 :: End Week [nobr]
 
-<<if $personalAttention.length > 0>>
-	<<if !$personalAttention.trainingRegimen.includes("explore her sexuality")>>
-		<<set $PC.slaving += 0.1>>
-	<</if>>
-<</if>>
 <<set State.expired.length = 0>>
 
 <<setupLastWeeksCash>>
diff --git a/src/uncategorized/persBusiness.tw b/src/uncategorized/persBusiness.tw
index 31e7c744dc0237060921bc09be4617a33c92c62b..1b5f7747402b2a2c1a550f4060bd0f0ae2f0d1e1 100644
--- a/src/uncategorized/persBusiness.tw
+++ b/src/uncategorized/persBusiness.tw
@@ -737,7 +737,7 @@
 			<<set _upgradeCount += 1>>
 		<</if>>
 		<<set _dataGain = _upgradeCount * 200>>
-		<<if !isInt(_dataGain)>>
+		<<if !Number.isInteger(_dataGain)>>
 			<br>@@.red;Error, dataGain is NaN@@
 		<<else>>
 			You are selling the data collected by your security department, which earns a discreet sum of @@.yellowgreen;<<print cashFormat(_dataGain)>>@@.
@@ -855,7 +855,7 @@ Routine upkeep of your demesne costs @@.yellow;<<print cashFormat($costs)>>.@@
 		<</if>>
 		<<set _income = Math.trunc(_income * 0.5)>>
 		This week we made @@.yellowgreen;<<print cashFormat(_income)>>.@@
-		<<if !isInt(_income)>>
+		<<if !Number.isInteger(_income)>>
 			<br>@@.red;Error failed to calculate income@@
 		<<else>>
 			<<run cashX(_income, "personalBusiness")>>
diff --git a/src/uncategorized/ptWorkaround.tw b/src/uncategorized/ptWorkaround.tw
index 181ba9c38236c007b614e2d9d47ae7a665f6db0e..f717b9a850538ad6f147ac8f5e65583b697e8b3e 100644
--- a/src/uncategorized/ptWorkaround.tw
+++ b/src/uncategorized/ptWorkaround.tw
@@ -82,6 +82,7 @@
 	<<set $activeSlave.training = 0>>
 
 <<case "look after her">>
+	<<set $PC.slaving += 0.1>>
 	<<if $activeSlave.relationship == -3 && $activeSlave.fetish == "mindbroken">>
 		Since $activeSlave.slaveName is your wife and not all there, you keep $him under a watchful eye to make sure no harm comes to the broken $girl. $He almost seems in better spirits under your care, not that it will matter in an hour or two.
 		<<set $activeSlave.kindness++>>
@@ -108,7 +109,6 @@
 	<<set $activeSlave.training = 0>>
 
 <<case "soften her behavioral flaw">>
-	<<set $PC.slaving += 0.2>>
 	<<if ($activeSlave.behavioralFlaw == "none")>>
 		$activeSlave.slaveName got over $his behavioral flaw without you;
 		@@.yellow;$his training assignment has defaulted to
@@ -156,8 +156,10 @@
 			$activeSlave.slaveName remains devoted to an old world faith that serves $him as a reservoir of mental resilience. Like all such beliefs, $hers has certain sexual elements; you amuse yourself by forcing $him to break them, and rewarding $him generously when $he does.
 		<</if>>
 		<<if $activeSlave.training < 100>>
+			<<set $PC.slaving += 0.2>>
 			You make progress, but $he's the same at the end of the week.
 		<<else>>
+			<<set $PC.slaving += 0.5>>
 			<<set $activeSlave.training = 0>>
 			By the end of the week, @@.green;you resolve $his flaw into something special.@@ @@.hotpink;$His obedience has increased.@@
 			<<run SoftenBehavioralFlaw($activeSlave)>>
@@ -198,7 +200,6 @@
 	<</if>>
 
 <<case "soften her sexual flaw">>
-	<<set $PC.slaving += 0.2>>
 	<<if ($activeSlave.sexualFlaw == "none")>>
 		$activeSlave.slaveName got over $his sexual flaw without you,
 		@@.yellow;$his training assignment has defaulted to
@@ -281,8 +282,10 @@
 			has something. You should probably report this as nobody knows what is currently happening. $His flaw was supposed to be $activeSlave.sexualFlaw.
 		<</switch>>
 		<<if $activeSlave.training < 100>>
+			<<set $PC.slaving += 0.2>>
 			You make progress, but $he's the same at the end of the week.
 		<<else>>
+			<<set $PC.slaving += 0.5>>
 			<<set $activeSlave.training = 0>>
 			By the end of the week, @@.green;you resolve $his flaw into something special.@@ @@.hotpink;$His obedience has increased.@@
 			<<run SoftenSexualFlaw($activeSlave)>>
@@ -434,15 +437,19 @@
 	<<if ($activeSlave.trust < -20) && ($activeSlave.fetishKnown == 0)>>
 		$He is now fully broken; @@.yellow;$his training assignment has defaulted to exploring $his sexuality.@@
 		<<set $personalAttention[_ptwi].trainingRegimen = "explore her sexuality">>
+		<<set $PC.slaving += 0.5>>
 	<<elseif ($activeSlave.trust < -20)>>
 		$He is now fully broken; @@.yellow;$his training assignment has defaulted to fostering devotion.@@
 		<<set $personalAttention[_ptwi].trainingRegimen = "build her devotion">>
+		<<set $PC.slaving += 0.5>>
 	<<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishKnown == 0)>>
 		$He is now obedient and attentive; @@.yellow;$his training assignment has defaulted to exploring $his sexuality.@@
 		<<set $personalAttention[_ptwi].trainingRegimen = "explore her sexuality">>
+		<<set $PC.slaving += 0.5>>
 	<<elseif ($activeSlave.devotion > 20)>>
 		$He is now obedient and attentive; @@.yellow;$his training assignment has defaulted to fostering devotion.@@
 		<<set $personalAttention[_ptwi].trainingRegimen = "build her devotion">>
+		<<set $PC.slaving += 0.5>>
 	<</if>>
 	<<set $activeSlave.training = 0>>
 
@@ -511,11 +518,11 @@
 	<<if ($activeSlave.devotion > 20)>>
 		$He is now fully broken; @@.yellow;$his training assignment has defaulted to fostering devotion.@@
 		<<set $personalAttention[_ptwi].trainingRegimen = "build her devotion">>
+		<<set $PC.slaving += 1>>
 	<</if>>
 	<<set $activeSlave.training = 0>>
 
 <<case "fix her behavioral flaw">>
-	<<set $PC.slaving += 0.2>>
 	<<if ($activeSlave.behavioralFlaw == "arrogant")>>
 		$activeSlave.slaveName seems to think $he's better than everyone else. Naturally, as $his owner you have the means to correct this sad misapprehension. As you train $him during the week, you ensure that $he submits to anyone and everyone. $He is rarely permitted to enjoy sex under your tutelage, but is instead required to use $his mouth and hands to get others off. $He cleans, washes, and serves.
 		<<set $activeSlave.oralCount += 10, $oralTotal += 10>>
@@ -551,8 +558,10 @@
 	<</if>>
 	<<set $activeSlave.training += 40>> /* fixing is easier than softening */
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		You make progress, but $he's the same at the end of the week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		<<set $activeSlave.training = 0>>
 		By the end of the week, @@.green;you break $him of $his bad habits.@@ @@.hotpink;$His obedience has increased.@@
 		<<set $activeSlave.behavioralFlaw = "none", $activeSlave.devotion += 4>>
@@ -589,7 +598,6 @@
 	<</if>>
 
 <<case "fix her sexual flaw">>
-	<<set $PC.slaving += 0.2>>
 	<<switch $activeSlave.sexualFlaw>>
 	<<case "hates oral">>
 		$activeSlave.slaveName has a powerful gag reflex. As a result, it's pretty unpleasant to receive oral sex from $him, no matter how hard $he tries. You apply various inventive techniques for addressing this, all of which involve requiring $him to repeatedly deepthroat some object or other.
@@ -683,8 +691,10 @@
 	<</switch>>
 	<<set $activeSlave.training += 40>> /* fixing is easier than softening */
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		You make progress, but $he's the same at the end of the week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		<<set $activeSlave.training = 0>>
 		By the end of the week, @@.green;you break $him of $his bad habits.@@ @@.hotpink;$His obedience has increased.@@
 		<<set $activeSlave.sexualFlaw = "none", $activeSlave.devotion += 4>>
@@ -723,7 +733,7 @@
 	<</if>>
 
 <<case "explore her sexuality">>
-	<<set $PC.slaving += 0.2>>
+	<<set $PC.slaving += 0.1>>
 	<<set $activeSlave.attrKnown = 1>>
 	You set about investigating $his sexuality.
 	<<if ($activeSlave.devotion < -20) && ($activeSlave.trust >= -20)>>
@@ -862,311 +872,339 @@
 	<<BasicTrainingDefaulter>>
 
 <<case "induce arrogance">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to incite $him to arrogance, you praise $him effusively, and give orders that others are to do so as well. Other slaves are punished for things $he's allowed to get away with.
 	<<InduceFlawLenityEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He isn't seriously affected; you'll have to be more subtle next week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		<<set $activeSlave.training = 0>>
 		$He begins to think $himself special, and is now @@.red;arrogant.@@
 		<<set $activeSlave.behavioralFlaw = "arrogant">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce bitchiness">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to induce $him to bitchiness, you keep $him in your office and induce $him to criticize other slaves, rewarding $him when $he's especially catty.
 	<<InduceFlawLenityEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He goes along, but remains cautious and will need more practice.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He starts making @@.red;bitchy@@ remarks without being prompted.
 		<<set $activeSlave.behavioralFlaw = "bitchy">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce odd behavior">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to abuse $him into odd behavior, you target $him for a campaign of surprise sex. You constantly ambush $him, shove $him onto the ground, and fuck $him. Sometimes $he wakes up from bad dreams to find you penetrating $him.
 	<<InduceFlawAbuseEffects>>
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to tolerate the abuse.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He starts @@.red;behaving oddly,@@ jumping at noises and mumbling to $himself.
 		<<set $activeSlave.behavioralFlaw = "odd">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce hatred of men">>
-	<<set $PC.slaving += 0.2>>
 	In order to make $him hate men, you sometimes simply <<if $PC.dick == 1>>stick your dick in $him without asking<<else>>stuff a strap-on inside $him without asking<</if>>, and sometimes force shockingly juvenile pranks on $him. $He is regularly smacked in the face with floppy dildos.
 	<<InduceFlawAbuseEffects>>
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He focuses more on you than on the masculine aspects of this. You'll need to be more subtle next week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		You notice $him starting to @@.red;shoot hateful glances@@ at any men $he sees.
 		<<set $activeSlave.behavioralFlaw = "hates men">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce hatred of women">>
-	<<set $PC.slaving += 0.2>>
 	In order to make $him hate women, you keep $him in your office when $he's not otherwise occupied, and <<if $PC.vagina == 0>>make $him eat other slaves out<<else>>sit on $his face<</if>> until $he's thoroughly sick of pussy.
 	<<InduceFlawAbuseEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He focuses more on you than on the feminine aspects of this. You'll need to be more subtle next week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		You notice $him starting to @@.red;shoot hateful glances@@ at any vaginas $he sees.
 		<<set $activeSlave.behavioralFlaw = "hates women">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce gluttony">>
-	<<set $PC.slaving += 0.2>>
 	Inducing gluttony is harder than inducing anorexia; you force $him to orgasm when $he's eating, and praise $him effusively when $he gains weight. You also provide $him with ample rations for stress eating.
 	<<set $activeSlave.training -= 20>> /* more difficult training */
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He eats when ordered, but isn't deeply affected. $He'll need more practice being a pig.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		You notice $him starting to @@.red;enjoy eating@@ for its own sake, even when $he's not hungry.
 		<<set $activeSlave.behavioralFlaw = "gluttonous">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce anorexia">>
-	<<set $PC.slaving += 0.2>>
 	You criticize $him cruelly whenever $he eats, and praise thinner slaves to $his face at every opportunity.
 	<<InduceFlawAbuseEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He continues consuming $his rations when ordered, and will need further training.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He begins to @@.red;eat only when repeatedly ordered to.@@
 		<<set $activeSlave.behavioralFlaw = "anorexic">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce religious devotion">>
-	<<set $PC.slaving += 0.2>>
 	You direct a campaign of abuse and threats at $him, and surreptitiously ensure that a little religious text from $his home country finds its way into a hiding place in $his living area.
 	<<InduceFlawAbuseEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He keeps $his head down and shows no sign of religious introspection, at least this week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He begins to read it when $he thinks $he's alone, and @@.red;talks to God@@ when $he thinks only He is listening.
 		<<set $activeSlave.behavioralFlaw = "devout">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce liberation">>
-	<<set $PC.slaving += 0.2>>
 	You direct a campaign of abuse and threats at $him, making sure to threaten $him with the absolute worst of slavery in your arcology. You also arrange for $him to witness other citizen's slaves in situations that aren't much fun.
 	<<InduceFlawAbuseEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to endure the abuse, unknowingly condemning $himself to more.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		A deep @@.red;anger about slavery@@ builds within $him.
 		<<set $activeSlave.behavioralFlaw = "liberated">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce hatred of oral">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to force $him to dislike oral sex, you're forced to use a complicated and refined slave breaking technique: constantly raping $his face.
 	<<InduceFlawAbuseEffects>>
 	<<set $activeSlave.oralCount += 10, $oralTotal += 10>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to comply with the oral abuse, unknowingly condemning $himself to more.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		After gagging enough, $he finally starts to @@.red;hate oral.@@
 		<<set $activeSlave.sexualFlaw = "hates oral">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce hatred of anal">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to force $him to dislike anal sex, you're forced to use a complicated and refined slave breaking technique: constantly raping $his ass.
 	<<if !canDoAnal($activeSlave)>>Every time you catch $him with $his chastity off, you're there to penetrate $his rectum<</if>>.
 	<<InduceFlawAbuseEffects>>
 	<<= AnalVCheck(10)>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to comply with your abuse of $his butthole, unknowingly condemning $himself to more assrape.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		After feeling $his poor sphincter grow sorer and sorer, $he starts to @@.red;hate anal.@@
 		<<set $activeSlave.sexualFlaw = "hates anal">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce hatred of penetration">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to force $him to dislike penetration, you're forced to use a complicated and refined slave breaking technique: constantly raping $him.
 	<<InduceFlawAbuseEffects>>
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to comply with your abuse, unknowingly condemning $himself to more of it.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		After feeling $his poor holes grow sorer and sorer, $he starts to @@.red;hate getting fucked.@@
 		<<set $activeSlave.sexualFlaw = "hates penetration">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce shame">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to force shame on $him, you keep $him in your office whenever $he's not otherwise occupied, and heap derision on $him at every opportunity, even inviting visitors to join you in chats about how unattractive and worthless $he is.
 	<<InduceFlawAbuseEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to keep $his chin up, unknowingly condemning $himself to more of this abuse.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He wants nothing more than to hide in corner and cry, and is now @@.red;shamefast.@@
 		<<set $activeSlave.sexualFlaw = "shamefast">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce sexual idealism">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to induce $him to sexual idealism, you keep $him in your office, and when the two of you are all alone, gossip with $him about other slaves and even citizens. You do your best to encourage $him to believe absurdities.
 	<<InduceFlawLenityEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He doesn't know what to make of this; you'll have to keep at it.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He follows along, and is now @@.red;sexually idealistic.@@
 		<<set $activeSlave.sexualFlaw = "idealistic">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce sexual repression">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to force sexual repression on $him, you keep $him in your office whenever $he's not otherwise occupied. You use the monitoring systems to reveal $his sexual arousal whenever it appears, and castigate and punish $him for it.
 	<<InduceFlawAbuseEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to keep $his chin up, unknowingly condemning $himself to more of this abuse.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He desperately tries to avoid even thinking about subjects that get $him punished, and is now @@.red;sexually repressed.@@
 		<<set $activeSlave.sexualFlaw = "repressed">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce sexual apathy">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to force sexual apathy on $him, you keep $him in your office whenever $he's not otherwise occupied. You use $him regularly, and punish $him whenever $he shows any sign of enjoyment.
 	<<InduceFlawAbuseEffects>>
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He continues to experience arousal when fucked, and will need more of this treatment.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He desperately tries to avoid arousal, and is now @@.red;sexually apathetic.@@
 		<<set $activeSlave.sexualFlaw = "apathetic">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce crudity">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to force sexual crudeness on $him, you keep $him in your office whenever $he's not otherwise occupied, and degrade $him cruelly. You relax the normal cleanliness rules, and require $him to leave $his used holes as they are until $he's too disgusting to fuck.
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<InduceFlawAbuseEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He does $his best to tolerate the unclean feelings, condemning $himself to more of this.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He slowly stops caring, and is now @@.red;sexually crude.@@
 		<<set $activeSlave.sexualFlaw = "crude">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce judgement">>
-	<<set $PC.slaving += 0.2>>
 	Since you've decided to make $him sexually judgemental, you keep $him in your office and fuck $him, <<if $PC.dick == 1>>praising $him whenever $he takes your big dick well<<else>>using a huge strap-on on $him and praising $him when $he takes it like a good girl<</if>>. You also judge others' endowments in $his presence.
 	<<InduceFlawLenityEffects>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He writes this off as bravado, and will need more training.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He starts to consider $himself reserved for special sexual treatment, and is now @@.red;sexually judgemental.@@
 		<<set $activeSlave.sexualFlaw = "judgemental">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce cum addiction">>
-	<<set $PC.slaving += 0.2>>
 	The cumslut is quite pleased when you order $him to stay in your office whenever $he can for use as one of your personal oral toys. You carefully limit $his orgasms to when <<if $PC.dick == 1>>you're blowing your load down $his throat<<else>>$he's swallowing your pussyjuice<</if>>, and make $his oral adventures predictably regular.
 	<<set $activeSlave.oralCount += 10, $oralTotal += 10>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He enjoys giving you lots of oral, but will need more training to develop psychological addiction to it.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He begins to develop a psychological @@.yellow;addiction to cum.@@
 		<<set $activeSlave.sexualFlaw = "cum addict">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce anal addiction">>
-	<<set $PC.slaving += 0.2>>
 	The buttslut is quite pleased when you order $him to stay in your office<<if !canDoAnal($activeSlave)>>and remove $his chastity<</if>> whenever $he can for use as one of your personal anal toys. You make $his anal orgasms predictably regular, doing your best to inculcate reliance on them.
 	<<= AnalVCheck(10)>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He enjoys all the anal attention, but will need more training to develop psychological addiction to buttsex.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He begins to develop a psychological @@.yellow;addiction to anal sex.@@
 		<<set $activeSlave.sexualFlaw = "anal addict">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce attention whoring">>
-	<<set $PC.slaving += 0.2>>
 	The humiliation slut is quite pleased when you order $him to stay in your office whenever $he can, and fucking $him whenever other slaves are present. You do your best to focus $his attention on how the others react to the spectacle.
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He enjoys all the humiliation, but will need more training to become a true attention whore.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He becomes a @@.yellow;true attention whore,@@ caring more about the spectators than the sex.
 		<<set $activeSlave.sexualFlaw = "attention whore">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce breast growth obsession">>
-	<<set $PC.slaving += 0.2>>
 	You inspect $his breasts multiple times a day, and praise $him effusively when they grow at all. You treat it as though it were something $he could control personally.
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He enjoys your attention to $his favorite part of $himself, but doesn't truly internalize your focus on their growth.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He begins to believe you despite $himself, and becomes @@.yellow;obsessed with breast growth.@@
 		<<set $activeSlave.sexualFlaw = "breast growth">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce abusiveness">>
-	<<set $PC.slaving += 0.2>>
 	The dom is gratified when you order $him to stay in your office whenever $he can to fuck any slave you feel like throwing $his way. You do your best to limit $his menu items to reluctant or even rebellious slaves, and praise $him when $he forces $himself on them.
 	<<set $activeSlave.penetrativeCount += 20, $penetrativeTotal += 20>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He has fun, but $he continues to enjoy getting off more than getting to use bitches. $He'll need more practice.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He becomes @@.yellow;sexually abusive,@@ looking over each slave that comes into your office in the hope they'll resist.
 		<<set $activeSlave.sexualFlaw = "abusive">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce maliciousness">>
-	<<set $PC.slaving += 0.2>>
 	The sadist is gratified when you order $him to stay in your office whenever $he can to have $his way with any slave you feel like throwing $his way. You do your best to limit $his menu items to rebellious slaves, and praise $him when $his sadism makes $him an effective punishment tool.
 	<<set $activeSlave.penetrativeCount += 20, $penetrativeTotal += 20>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He enjoys $himself, but still betrays occasional concern when slaves are really broken by what $he does to them. $He'll need more practice.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He becomes @@.yellow;sexually malicious,@@ going so far as to lick tears off $his victims' faces.
 		<<set $activeSlave.sexualFlaw = "malicious">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce self hatred">>
-	<<set $PC.slaving += 0.2>>
 	You order the masochist to stay in your office whenever $he's not working or resting. You fuck $him cruelly, going beyond the pain $he enjoys into harsh degradation. And every time you use $him, you make sure to tell $him how useless $he is.
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He gets off on the pain, but $his sense of self isn't seriously affected this week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He becomes @@.yellow;sexually self hating,@@ and tearfully begs to you do worse to $him, no matter how bad it gets.
 		<<set $activeSlave.sexualFlaw = "self hating">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce sexual self neglect">>
-	<<set $PC.slaving += 0.2>>
 	You order the sub to stay in your office whenever $he's not working or resting, and use $his body for your pleasure. The instant you climax, you go back to your work or to another slave, treating $him like a piece of used tissue.
 	<<if canDoVaginal($activeSlave)>><<= VaginalVCheck(10)>><<elseif canDoAnal($activeSlave)>><<= AnalVCheck(10)>><<else>><<set $activeSlave.oralCount += 10, $oralTotal += 10>><</if>>
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He accepts $his utterly submissive role, but $his sense of self isn't seriously affected this week.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He becomes @@.yellow;sexually self neglectful,@@ and loses all expectation that those who use $him will address $his pleasure at all.
 		<<set $activeSlave.sexualFlaw = "neglectful">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <<case "induce breeding obsession">>
-	<<set $PC.slaving += 0.2>>
 	You order the pregnant slut to stay in your office whenever $he's not working or resting.
 	<<if $activeSlave.pregKnown == 0>>Since $he's not pregnant, you keep $him rigged up with an enormous sympathy belly when $he's there.<</if>> Rather than fucking $him, you praise $his pregnancy effusively, and only allow $him to get off when you're doing so.
 	<<if $activeSlave.training < 100>>
+		<<set $PC.slaving += 0.2>>
 		$He enjoys $himself, but mostly because of the pleasure. $He'll need more training.
 	<<else>>
+		<<set $PC.slaving += 0.5>>
 		$He develops an @@.yellow;obsession with breeding,@@ and begins to stroke $his belly in a disturbingly masturbatory way.
 		<<set $activeSlave.sexualFlaw = "breeder">>
 		<<BasicTrainingDefaulter>>
 	<</if>>
 <</switch>>
+<<set $PC.slaving = Math.clamp($PC.slaving, -100, 100)>>
 
 <<if $activeSlave.ID == $slaves[$i].ID>>
 	<<set $slaves[$i] = $activeSlave>>
diff --git a/src/uncategorized/randomNonindividualEvent.tw b/src/uncategorized/randomNonindividualEvent.tw
index 73807103bfdec1953598d5de97f472a08acb001d..20e8a6ebf526c0e6728d4e1b7681920f8ceefe67 100644
--- a/src/uncategorized/randomNonindividualEvent.tw
+++ b/src/uncategorized/randomNonindividualEvent.tw
@@ -221,7 +221,7 @@
 
 	/* Fetish Interest Events */
 
-	<<set $buttslutID = 0, $cumslutID = 0, $humiliationID = 0, $subID = 0, $pregnancyID = 0, $masochistID = 0, $boobsID = 0>>
+	<<set $buttslutID = 0, $cumslutID = 0, $humiliationID = 0, $domID = 0, $subID = 0, $pregnancyID = 0, $masochistID = 0, $boobsID = 0>>
 
 	<<for $i = 0; $i < $slaves.length; $i++>>
 		<<if ($slaves[$i].fetishKnown == 1) && ($slaves[$i].fetishStrength > 95) && isSlaveAvailable($slaves[$i])>>
@@ -237,6 +237,11 @@
 						<<set $cumslutID = $slaves[$i].ID>>
 					<</if>>
 				<</if>>
+			<<elseif ($slaves[$i].fetish == "dom")>>
+				<<if ($domID == 0)>>
+					/* TODO: these conditions will need to be written */
+						<<set $domID = $slaves[$i].ID>>
+				<</if>>
 			<<elseif ($slaves[$i].fetish == "submissive")>>
 				<<if ($subID == 0)>>
 					<<if (($slaves[$i].anus > 0 && canDoAnal($slaves[$i])) || ($slaves[$i].vagina > 0 && canDoVaginal($slaves[$i])) && $slaves[$i].belly < 30000)>>
@@ -271,7 +276,7 @@
 		<</if>>
 	<</for>>
 
-	<<set $buttslutInterestTargetID = 0, $cumslutInterestTargetID = 0, $submissiveInterestTargetID = 0, $humiliationInterestTargetID = 0, $boobsInterestTargetID = 0, $pregnancyInterestTargetID = 0, $masochistInterestTargetID = 0>>
+	<<set $buttslutInterestTargetID = 0, $cumslutInterestTargetID = 0, $dominantInterestTargetID = 0, $submissiveInterestTargetID = 0, $humiliationInterestTargetID = 0, $boobsInterestTargetID = 0, $pregnancyInterestTargetID = 0, $masochistInterestTargetID = 0>>
 
 	<<for $i = 0; $i < $slaves.length; $i++>>
 		<<if ($slaves[$i].speechRules != "restrictive")>>
@@ -287,7 +292,7 @@
 						<</if>>
 						<<set $cumslutInterestTargetID = $slaves[$i].ID>>
 					<</if>>
-					<<if ($dominantID != 0) && ($dominantInterestTargetID == 0)>>
+					<<if ($domID != 0) && ($dominantInterestTargetID == 0)>>
 						<<set $REFIevent.push("dom")>>
 						<<set $dominantInterestTargetID = $slaves[$i].ID>>
 					<</if>>
diff --git a/src/uncategorized/remoteSurgery.tw b/src/uncategorized/remoteSurgery.tw
index a8b78295d47aa26319f1214a5a7343b7a88a5203..97e847e6ddb0a9a5549c4ca52f4d61e2ab3352a0 100644
--- a/src/uncategorized/remoteSurgery.tw
+++ b/src/uncategorized/remoteSurgery.tw
@@ -162,7 +162,7 @@ $He has
 	normal ears.
 <<elseif $activeSlave.earShape == "damaged">>
 	damaged ears.
-	| [[Repair|Surgery Degradation][$activeSlave.earShape = "normal", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earRestore"]]
+	| [[Repair|Surgery Degradation][$activeSlave.earShape = "normal", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earRestore"]]
 <<elseif $activeSlave.earShape == "pointy">>
 	small elfin ears.
 <<elseif $activeSlave.earShape == "elven">>
@@ -179,11 +179,11 @@ $He has
 	//$His indenture forbids elective surgery//
 <<else>>
 	<<if $activeSlave.earShape != "normal" && $activeSlave.earShape != "none">>
-		[[Restore to normal|Surgery Degradation][$activeSlave.earShape = "normal", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earRestore"]]
+		[[Restore to normal|Surgery Degradation][$activeSlave.earShape = "normal", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earRestore"]]
 	<</if>>
 	<<if $activeSlave.earShape != "normal" && $activeSlave.earShape != "none" && $seeExtreme == 1 && $activeSlave.indentureRestrictions < 1>> | <</if>>
 	<<if $activeSlave.earShape != "none" && $seeExtreme == 1 && $activeSlave.indentureRestrictions < 1>>
-		[[Remove them|Surgery Degradation][$activeSlave.earShape = "none", $cash -= $surgeryCost, $activeSlave.health -= 20, $surgeryType = "earGone"]]
+		[[Remove them|Surgery Degradation][$activeSlave.earShape = "none", cashX(forceNeg($surgeryCost), $activeSlave.health -= 20, $surgeryType = "earGone"]]
 	<</if>>
 	<<if $activeSlave.earShape == "none">>
 		<<if $activeSlave.hears != -2 && $activeSlave.earImplant != 1>>
@@ -194,14 +194,14 @@ $He has
 		<</if>>
 	<<else>>
 		<<if $activeSlave.earShape != "pointy">>
-			| [[Reshape into small elfin ears|Surgery Degradation][$activeSlave.earShape = "pointy", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMinor"]]
+			| [[Reshape into small elfin ears|Surgery Degradation][$activeSlave.earShape = "pointy", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMinor"]]
 		<</if>>
 		<<if $surgeryUpgrade == 1>>
 			<<if $activeSlave.earShape != "elven">>
-				| [[Reshape into long elf ears|Surgery Degradation][$activeSlave.earShape = "elven", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMajor"]]
+				| [[Reshape into long elf ears|Surgery Degradation][$activeSlave.earShape = "elven", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMajor"]]
 			<</if>>
 			<<if $activeSlave.earShape != "ushi">>
-				| [[Reshape into bovine ears|Surgery Degradation][$activeSlave.earShape = "ushi", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMajor"]]
+				| [[Reshape into bovine ears|Surgery Degradation][$activeSlave.earShape = "ushi", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMajor"]]
 			<</if>>
 		<</if>>
 	<</if>>
@@ -230,29 +230,29 @@ $He has
 		//$His indenture forbids elective surgery//
 	<<else>>
 		<<if $activeSlave.earT != "none" && $seeExtreme == 1 && $activeSlave.indentureRestrictions < 1>>
-			[[Remove them|Surgery Degradation][$activeSlave.earT = "none", $cash -= $surgeryCost, $activeSlave.health -= 20, $surgeryType = "earGone"]]
+			[[Remove them|Surgery Degradation][$activeSlave.earT = "none", cashX(forceNeg($surgeryCost), $activeSlave.health -= 20, $surgeryType = "earGone"]]
 		<</if>>
 		<<if $activeSlave.earT == "normal">>
 			<<if $activeSlave.earT != "neko">>
-				| [[Reshape into cat Ears|Surgery Degradation][$activeSlave.earT = "neko", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMajor"]]
+				| [[Reshape into cat Ears|Surgery Degradation][$activeSlave.earT = "neko", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMajor"]]
 			<</if>>
 			<<if $activeSlave.earT != "inu">>
-				| [[Reshape into dog Ears|Surgery Degradation][$activeSlave.earT = "inu", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMajor"]]
+				| [[Reshape into dog Ears|Surgery Degradation][$activeSlave.earT = "inu", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMajor"]]
 			<</if>>
 			<<if $activeSlave.earT != "kit">>
-				| [[Reshape into fox Ears|Surgery Degradation][$activeSlave.earT = "kit", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMajor"]]
+				| [[Reshape into fox Ears|Surgery Degradation][$activeSlave.earT = "kit", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMajor"]]
 			<</if>>
 			<<if $activeSlave.earT != "tanuki">>
-				| [[Reshape into tanuki Ears|Surgery Degradation][$activeSlave.earT = "tanuki", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMajor"]]
+				| [[Reshape into tanuki Ears|Surgery Degradation][$activeSlave.earT = "tanuki", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMajor"]]
 			<</if>>
 		<<else>>
 			<br>
 			<<if $activeSlave.earTColor == "hairless">>
 				They are completely bald.
-				[[Implant hair mimicking fibers|Surgery Degradation][$activeSlave.earTColor = $activeSlave.hColor, $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMinor"]]
+				[[Implant hair mimicking fibers|Surgery Degradation][$activeSlave.earTColor = $activeSlave.hColor, cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMinor"]]
 			<<else>>
 				They are covered by a multitude of implanted $activeSlave.earTColor fibers mimicking hair.
-				[[Remove them|Surgery Degradation][$activeSlave.earTColor = "hairless", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "earMinor"]]
+				[[Remove them|Surgery Degradation][$activeSlave.earTColor = "hairless", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "earMinor"]]
 			<</if>>
 		<</if>>
 	<</if>>
@@ -297,20 +297,20 @@ $He has <<if $activeSlave.horn == "none">>no horns<<else>>$activeSlave.horn<</if
 <<if $activeSlave.indentureRestrictions >= 2>>
 	//$His indenture forbids elective surgery//
 <<elseif $activeSlave.horn != "none">>
-	[[Remove them|Surgery Degradation][$activeSlave.horn = "none", $activeSlave.hornColor = "none", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "hornGone"]]<</if>>
+	[[Remove them|Surgery Degradation][$activeSlave.horn = "none", $activeSlave.hornColor = "none", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "hornGone"]]<</if>>
 	Give $him:
 <<if $activeSlave.horn != "curved succubus horns">>
-	[[Succubus horns|Surgery Degradation][$activeSlave.horn = "curved succubus horns", $activeSlave.hornColor = "jet black", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
+	[[Succubus horns|Surgery Degradation][$activeSlave.horn = "curved succubus horns", $activeSlave.hornColor = "jet black", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
 <<if $activeSlave.horn != "backswept horns">>
-	| [[Backswept horns|Surgery Degradation][$activeSlave.horn = "backswept horns", $activeSlave.hornColor = "jet black", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
+	| [[Backswept horns|Surgery Degradation][$activeSlave.horn = "backswept horns", $activeSlave.hornColor = "jet black", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
 <<if $activeSlave.horn != "cow horns">>
-	| [[Bovine horns|Surgery Degradation][$activeSlave.horn = "cow horns", $activeSlave.hornColor = "ivory", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
+	| [[Bovine horns|Surgery Degradation][$activeSlave.horn = "cow horns", $activeSlave.hornColor = "ivory", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
 <<if $activeSlave.horn != "one long oni horn">>
-	| [[an oni horn|Surgery Degradation][$activeSlave.horn = "one long oni horn", $activeSlave.hornColor = $activeSlave.skin, $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
+	| [[an oni horn|Surgery Degradation][$activeSlave.horn = "one long oni horn", $activeSlave.hornColor = $activeSlave.skin, cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
 <<if $activeSlave.horn != "two long oni horns">>
-	| [[2 oni horns|Surgery Degradation][$activeSlave.horn = "two long oni horns", $activeSlave.hornColor = $activeSlave.skin, $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
+	| [[2 oni horns|Surgery Degradation][$activeSlave.horn = "two long oni horns", $activeSlave.hornColor = $activeSlave.skin, cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
 <<if $activeSlave.horn != "small horns">>
-	| [[Small horns|Surgery Degradation][$activeSlave.horn = "small horns", $activeSlave.hornColor = "ivory", $cash -= $surgeryCost, $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
+	| [[Small horns|Surgery Degradation][$activeSlave.horn = "small horns", $activeSlave.hornColor = "ivory", cashX(forceNeg($surgeryCost), $activeSlave.health -= 10, $surgeryType = "horn"]]<</if>>
 
 <br>&nbsp;&nbsp;&nbsp;&nbsp;
 $He has
diff --git a/src/uncategorized/saLongTermEffects.tw b/src/uncategorized/saLongTermEffects.tw
index 54d8be62416c4216083d21b4296171c4002a80df..a1468eaf50b0bbdd4143587e803c6480551b5f2e 100644
--- a/src/uncategorized/saLongTermEffects.tw
+++ b/src/uncategorized/saLongTermEffects.tw
@@ -1596,6 +1596,8 @@
 
 /* SMART PIERCING EFFECTS */
 
+<<set _vAcc = $slaves[$i].vaginalAccessory, _dAcc = $slaves[$i].dickAccessory>>	/* for brevity */
+
 <<if ($slaves[$i].clitPiercing == 3)>>
 	<<if $slaves[$i].fuckdoll > 0>>
 		$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing is slaved to $his stimulation systems.
@@ -1605,13 +1607,25 @@
 		<<switch $slaves[$i].clitSetting>>
 		<<case "none">>
 			$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-			<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+			<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 				and the bullet vibrator $he is wearing disrupt arousal, @@.red;reducing $his sex drive@@ and @@.mediumorchid;infuriating $him.@@
-				<<set $slaves[$i].devotion -= 3>>
-				<<if $slaves[$i].energy > 5>>
-					<<set $slaves[$i].energy -= 13>>
-				<<elseif $slaves[$i].energy > 0>>
-					<<set $slaves[$i].energy = 0>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].devotion -= 3>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].devotion -= 4>>
+				<</if>>
+				<<if _vAcc == "bullet vibrator">>
+					<<if $slaves[$i].energy > 5>>
+						<<set $slaves[$i].energy -= 13>>
+					<<elseif $slaves[$i].energy > 0>>
+						<<set $slaves[$i].energy = 0>>
+					<</if>>
+				<<elseif _vAcc == "smart bullet vibrator">>
+					<<if $slaves[$i].energy > 5>>
+						<<set $slaves[$i].energy -= 16>>
+					<<elseif $slaves[$i].energy > 0>>
+						<<set $slaves[$i].energy = 0>>
+					<</if>>
 				<</if>>
 			<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 				and the vibrating dildo in $his pussy disrupt arousal, @@.red;reducing $his sex drive@@ and @@.mediumorchid;infuriating $him.@@
@@ -1633,9 +1647,13 @@
 		<<case "all">>
 			<<if $slaves[$i].energy <= 95>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing encourage sex of all kinds, @@.green;increasing $his sex drive.@@
-					<<set $slaves[$i].energy += 5>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].energy += 5>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].energy += 7>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy encourage sex of all kinds, @@.green;increasing $his sex drive.@@
 					<<set $slaves[$i].energy += 5>>
@@ -1647,9 +1665,13 @@
 		<<case "women">>
 			<<if $slaves[$i].attrXX < 95>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing successfully @@.green;increase $his attraction to girls@@ by pleasuring $him when $he's around them.
-					<<set $slaves[$i].attrXX += 6+$assistant+$assistant>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].attrXX += 6+$assistant+$assistant>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].attrXX += 8+$assistant+$assistant>>
+					<</if>>
 					<<if $slaves[$i].energy < 80>>
 						This has the secondary effect of slightly @@.green;enhancing $his libido.@@
 						<<set $slaves[$i].energy += 2>>
@@ -1673,12 +1695,20 @@
 		<<case "anti-women">>
 			<<if $slaves[$i].attrXX > 0>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing successfully @@.green;suppress $his attraction to girls@@ by making $his private parts very uncomfortable when $he's around them.
-					<<set $slaves[$i].attrXX -= Math.clamp($slaves[$i].attrXX-(6+$assistant+$assistant),0,100)>>
-					<<if $slaves[$i].energy > 0>>
-						This has the secondary effect of slightly @@.red;reducing $his libido.@@
-						<<set $slaves[$i].energy -= 2>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].attrXX -= Math.clamp($slaves[$i].attrXX-(6+$assistant+$assistant),0,100)>>
+						<<if $slaves[$i].energy > 0>>
+							This has the secondary effect of slightly @@.red;reducing $his libido.@@
+							<<set $slaves[$i].energy -= 2>>
+						<</if>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].attrXX -= Math.clamp($slaves[$i].attrXX-(8+$assistant+$assistant),0,100)>>
+						<<if $slaves[$i].energy > 0>>
+							This has the secondary effect of slightly @@.red;reducing $his libido.@@
+							<<set $slaves[$i].energy -= 2>>
+						<</if>>
 					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy successfully @@.green;suppress $his attraction to girls@@ by making $his private parts very uncomfortable when $he's around them.
@@ -1699,9 +1729,13 @@
 		<<case "men">>
 			<<if $slaves[$i].attrXY < 95>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing successfully @@.green;increase $his attraction to guys@@ by pleasuring $him when $he's around cocks.
-					<<set $slaves[$i].attrXY += 6+$assistant+$assistant>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].attrXY += 6+$assistant+$assistant>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].attrXY += 8+$assistant+$assistant>>
+					<</if>>
 					<<if $slaves[$i].energy < 80>>
 						This has the secondary effect of slightly @@.green;enhancing $his libido.@@
 						<<set $slaves[$i].energy += 2>>
@@ -1725,12 +1759,20 @@
 		<<case "anti-men">>
 			<<if $slaves[$i].attrXY > 0>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing successfully @@.green;suppress $his attraction to guys@@ by making $his private parts very uncomfortable when $he's around them.
-					<<set $slaves[$i].attrXY -= Math.clamp($slaves[$i].attrXY-(6+$assistant+$assistant),0,100)>>
-					<<if $slaves[$i].energy > 0>>
-						This has the secondary effect of slightly @@.red;reducing $his libido.@@
-						<<set $slaves[$i].energy -= 2>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].attrXY -= Math.clamp($slaves[$i].attrXY-(6+$assistant+$assistant),0,100)>>
+						<<if $slaves[$i].energy > 0>>
+							This has the secondary effect of slightly @@.red;reducing $his libido.@@
+							<<set $slaves[$i].energy -= 2>>
+						<</if>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].attrXY -= Math.clamp($slaves[$i].attrXY-(8+$assistant+$assistant),0,100)>>
+						<<if $slaves[$i].energy > 0>>
+							This has the secondary effect of slightly @@.red;reducing $his libido.@@
+							<<set $slaves[$i].energy -= 2>>
+						<</if>>
 					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy successfully @@.green;suppress $his attraction to guys@@ by making $his private parts very uncomfortable when $he's around them.
@@ -1751,9 +1793,13 @@
 		<<case "vanilla">>
 			<<if ($slaves[$i].fetish != "none") && (_fetishChangeChance > random(0,100)-20*$assistant)>>
 				After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing encourage many orgasms during straightforward sex, @@.coral;$his sexuality returns to normal.@@
-					<<set $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy encourage many orgasms during straightforward sex, @@.coral;$his sexuality returns to normal.@@
 					<<set $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -1766,21 +1812,29 @@
 			<<if ($slaves[$i].fetish != "cumslut")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's using $his mouth.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's using $his mouth.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's using $his mouth.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms as $he performs oral sex, @@.lightcoral;$he develops a fetish for cum.@@
-						<<set $slaves[$i].fetish = "cumslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "cumslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "cumslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms as $he performs oral sex, @@.lightcoral;$he develops a fetish for cum.@@
 						<<set $slaves[$i].fetish = "cumslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -1791,9 +1845,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his oral fetish.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 8>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his oral fetish.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -1806,21 +1864,29 @@
 			<<if ($slaves[$i].fetish != "buttslut")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his rear hole is being fucked.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his rear hole is being fucked.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his rear hole is being fucked.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms when $his ass is being stimulated, @@.lightcoral;$he develops a fetish for being an anal bottom.@@
-						<<set $slaves[$i].fetish = "buttslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "buttslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "buttslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms when $his ass is being stimulated, @@.lightcoral;$he develops a fetish for being an anal bottom.@@
 						<<set $slaves[$i].fetish = "buttslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -1831,9 +1897,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his anal fetish.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his anal fetish.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -1846,21 +1916,29 @@
 			<<if ($slaves[$i].fetish != "boobs")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his tits are being touched.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his tits are being touched.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his tits are being touched.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms when $his nipples are being stimulated, @@.lightcoral;$he develops a fetish for $his tits.@@
-						<<set $slaves[$i].fetish = "boobs", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "boobs", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "boobs", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms when $his nipples are being stimulated, @@.lightcoral;$he develops a fetish for $his tits.@@
 						<<set $slaves[$i].fetish = "boobs", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -1871,9 +1949,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his boob fetish.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his boob fetish.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -1886,21 +1968,29 @@
 			<<if ($slaves[$i].fetish != "submissive")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being held down and used.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being held down and used.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being held down and used.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms when $he is restrained, @@.lightcoral;$he develops a fetish for submission.@@
-						<<set $slaves[$i].fetish = "submissive", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "submissive", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "submissive", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms when $he is restrained, @@.lightcoral;$he develops a fetish for submission.@@
 						<<set $slaves[$i].fetish = "submissive", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -1911,9 +2001,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his submission.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his submission.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -1926,21 +2020,29 @@
 			<<if ($slaves[$i].fetish != "humiliation")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's got an audience.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's got an audience.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's got an audience.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms when $he is being humiliated, @@.lightcoral;$he develops a fetish for humiliation.@@
-						<<set $slaves[$i].fetish = "humiliation", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "humiliation", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "humiliation", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms when $he is being humiliated, @@.lightcoral;$he develops a fetish for humiliation.@@
 						<<set $slaves[$i].fetish = "humiliation", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -1951,9 +2053,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his humiliation fetish.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his humiliation fetish.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -1966,21 +2072,29 @@
 			<<if ($slaves[$i].fetish != "pregnancy")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he feels like $he's being bred.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he feels like $he's being bred.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he feels like $he's being bred.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms during <<if $PC.dick == 1>>unprotected sex<<if $PC.vagina == 1>> and <</if>><</if>><<if $PC.vagina == 1>>loving contact with the female anatomy<</if>>, @@.lightcoral;$he begins to fantasize about pregnancy.@@
-						<<set $slaves[$i].fetish = "pregnancy", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "pregnancy", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "pregnancy", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms during <<if $PC.dick == 1>>unprotected sex<<if $PC.vagina == 1>> and <</if>><</if>><<if $PC.vagina == 1>>loving contact with the female anatomy<</if>>, @@.lightcoral;$he begins to fantasize about pregnancy.@@
 						<<set $slaves[$i].fetish = "pregnancy", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -1991,9 +2105,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his pregnancy fetish.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his pregnancy fetish.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -2006,21 +2124,29 @@
 			<<if ($slaves[$i].fetish != "dom")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when another slave is servicing $him.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when another slave is servicing $him.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when another slave is servicing $him.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms while $he's taking an active, dominant sexual role, @@.lightcoral;$he begins to enjoy dominance.@@
-						<<set $slaves[$i].fetish = "dom", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "dom", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "dom", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms while $he's taking an active, dominant sexual role, @@.lightcoral;$he begins to enjoy dominance.@@
 						<<set $slaves[$i].fetish = "dom", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -2031,9 +2157,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his dominance.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his dominance.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -2046,21 +2176,29 @@
 			<<if ($slaves[$i].fetish != "masochist")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being hurt.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being hurt.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being hurt.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms while $he's being beaten, @@.lightcoral;$he begins to enjoy pain.@@
-						<<set $slaves[$i].fetish = "masochist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "masochist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "masochist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms while $he's being beaten, @@.lightcoral;$he begins to enjoy pain.@@
 						<<set $slaves[$i].fetish = "masochist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -2071,9 +2209,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his masochism.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his masochism.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -2086,21 +2228,29 @@
 			<<if ($slaves[$i].fetish != "sadist")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>>
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he witnesses or even takes part in another slave's pain.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 25>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetishStrength -= 30>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy act to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he witnesses or even takes part in another slave's pain.
-						<<set $slaves[$i].fetishStrength -= 30>>
+						<<set $slaves[$i].fetishStrength -= 25>>
 					<<else>>
 						acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he witnesses or even takes part in another slave's pain.
 						<<set $slaves[$i].fetishStrength -= 20>>
 					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					After $his smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-					<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+					<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 						and the bullet vibrator $he is wearing encourage many orgasms while $he's involved in the abuse of other slaves, @@.lightcoral;$he begins to develop a sadistic streak.@@
-						<<set $slaves[$i].fetish = "sadist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+							<<set $slaves[$i].fetish = "sadist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+						<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+							<<set $slaves[$i].fetish = "sadist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+						<</if>>
 					<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 						and the vibrating dildo in $his pussy encourage many orgasms while $he's involved in the abuse of other slaves, @@.lightcoral;$he begins to develop a sadistic streak.@@
 						<<set $slaves[$i].fetish = "sadist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
@@ -2111,9 +2261,13 @@
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				$His smart <<if $slaves[$i].vagina > -1>>clit<<else>>frenulum<</if>> piercing
-				<<if $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+				<<if (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 					and the bullet vibrator $he is wearing @@.lightcoral;advance $his sadism.@@
-					<<set $slaves[$i].fetishStrength += 6>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 4>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength += 6>>
+					<</if>>
 				<<elseif $slaves[$i].vaginalAttachment == "vibrator">>
 					and the vibrating dildo in $his pussy @@.lightcoral;advance $his sadism.@@
 					<<set $slaves[$i].fetishStrength += 6>>
@@ -2124,7 +2278,7 @@
 			<</if>>
 		<</switch>>
 	<</if>>
-<<elseif $slaves[$i].vaginalAccessory == "bullet vibrator" || $slaves[$i].dickAccessory == "bullet vibrator">>
+<<elseif (_vAcc == "bullet vibrator" || _vAcc == "smart bullet vibrator") || (_dAcc == "bullet vibrator" || _dAcc == "smart bullet vibrator")>>
 	<<if $slaves[$i].fetish == "mindbroken">>
 		The effects of the bullet vibrator $he is wearing cannot reach $his shattered mind.
 	<<else>>
@@ -2132,173 +2286,329 @@
 		<<case "none">>
 			The bullet vibrator $he is wearing disrupt arousal, @@.red;reducing $his sex drive@@ and @@.mediumorchid;infuriating $him.@@
 				<<set $slaves[$i].devotion -= 3>>
-				<<if $slaves[$i].energy > 5>>
-					<<set $slaves[$i].energy -= 13>>
-				<<elseif $slaves[$i].energy > 0>>
-					<<set $slaves[$i].energy = 0>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<if $slaves[$i].energy > 5>>
+						<<set $slaves[$i].energy -= 13>>
+					<<elseif $slaves[$i].energy > 0>>
+						<<set $slaves[$i].energy = 0>>
+					<</if>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<if $slaves[$i].energy > 5>>
+						<<set $slaves[$i].energy -= 16>>
+					<<elseif $slaves[$i].energy > 0>>
+						<<set $slaves[$i].energy = 0>>
+					<</if>>
 				<</if>>
 		<<case "all">>
 			<<if $slaves[$i].energy <= 95>>
 				The bullet vibrator $he is wearing encourages sex of all kinds, @@.green;increasing $his sex drive.@@
-				<<set $slaves[$i].energy += 3>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].energy += 3>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].energy += 5>>
+				<</if>>
 			<</if>>
 		<<case "women">>
 			<<if $slaves[$i].attrXX < 95>>
 				The bullet vibrator $he is wearing successfully @@.green;increase $his attraction to girls@@ by pleasuring $him when $he's around them.
-				<<set $slaves[$i].attrXX += 6+$assistant+$assistant>>
-				<<if $slaves[$i].energy < 80>>
-					This has the secondary effect of slightly @@.green;enhancing $his libido.@@
-					<<set $slaves[$i].energy += 2>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].attrXX += 6+$assistant+$assistant>>
+					<<if $slaves[$i].energy < 80>>
+						This has the secondary effect of slightly @@.green;enhancing $his libido.@@
+						<<set $slaves[$i].energy += 2>>
+					<</if>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].attrXX += 8+$assistant+$assistant>>
+					<<if $slaves[$i].energy < 80>>
+						This has the secondary effect of slightly @@.green;enhancing $his libido.@@
+						<<set $slaves[$i].energy += 3>>
+					<</if>>
 				<</if>>
 			<</if>>
 		<<case "anti-women">>
 			<<if $slaves[$i].attrXX > 0>>
 				The bullet vibrator $he is wearing successfully @@.green;suppress $his attraction to girls@@ by making $his private parts very uncomfortable when $he's around them.
-				<<set $slaves[$i].attrXX -= Math.clamp($slaves[$i].attrXX-(6+$assistant+$assistant),0,100)>>
-				<<if $slaves[$i].energy > 0>>
-					This has the secondary effect of slightly @@.red;reducing $his libido.@@
-					<<set $slaves[$i].energy -= 2>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].attrXX -= Math.clamp($slaves[$i].attrXX-(6+$assistant+$assistant),0,100)>>
+					<<if $slaves[$i].energy > 0>>
+						This has the secondary effect of slightly @@.red;reducing $his libido.@@
+						<<set $slaves[$i].energy -= 2>>
+					<</if>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].attrXX -= Math.clamp($slaves[$i].attrXX-(8+$assistant+$assistant),0,100)>>
+					<<if $slaves[$i].energy > 0>>
+						This has the secondary effect of slightly @@.red;reducing $his libido.@@
+						<<set $slaves[$i].energy -= 3>>
+					<</if>>
 				<</if>>
 			<</if>>
 		<<case "men">>
 			<<if $slaves[$i].attrXY < 95>>
 				The bullet vibrator $he is wearing successfully @@.green;increase $his attraction to guys@@ by pleasuring $him when $he's around cocks.
-				<<set $slaves[$i].attrXY += 6+$assistant+$assistant>>
-				<<if $slaves[$i].energy < 80>>
-					This has the secondary effect of slightly @@.green;enhancing $his libido.@@
-					<<set $slaves[$i].energy += 2>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].attrXY += 6+$assistant+$assistant>>
+					<<if $slaves[$i].energy < 80>>
+						This has the secondary effect of slightly @@.green;enhancing $his libido.@@
+						<<set $slaves[$i].energy += 2>>
+					<</if>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].attrXY += 8+$assistant+$assistant>>
+					<<if $slaves[$i].energy < 80>>
+						This has the secondary effect of slightly @@.green;enhancing $his libido.@@
+						<<set $slaves[$i].energy += 3>>
+					<</if>>
 				<</if>>
 			<</if>>
 		<<case "anti-men">>
 			<<if $slaves[$i].attrXY > 0>>
 				The bullet vibrator $he is wearing successfully @@.green;suppress $his attraction to guys@@ by making $his private parts very uncomfortable when $he's around them.
-				<<set $slaves[$i].attrXY -= Math.clamp($slaves[$i].attrXY-(6+$assistant+$assistant),0,100)>>
-				<<if $slaves[$i].energy > 0>>
-					This has the secondary effect of slightly @@.red;reducing $his libido.@@
-					<<set $slaves[$i].energy -= 2>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].attrXY -= Math.clamp($slaves[$i].attrXY-(6+$assistant+$assistant),0,100)>>
+					<<if $slaves[$i].energy > 0>>
+						This has the secondary effect of slightly @@.red;reducing $his libido.@@
+						<<set $slaves[$i].energy -= 2>>
+					<</if>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].attrXY -= Math.clamp($slaves[$i].attrXY-(8+$assistant+$assistant),0,100)>>
+					<<if $slaves[$i].energy > 0>>
+						This has the secondary effect of slightly @@.red;reducing $his libido.@@
+						<<set $slaves[$i].energy -= 3>>
+					<</if>>
 				<</if>>
 			<</if>>
 		<<case "vanilla">>
 			<<if ($slaves[$i].fetish != "none") && (_fetishChangeChance > random(0,100)-20*$assistant)>>
 				The bullet vibrator $he is wearing encourages many orgasms during straightforward sex, @@.coral;$his sexuality returns to normal.@@
-				<<set $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+				<</if>>
 			<</if>>
 		<<case "oral">>
 			<<if ($slaves[$i].fetish != "cumslut")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's using $his mouth.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms as $he performs oral sex, @@.lightcoral;$he develops a fetish for cum.@@
-					<<set $slaves[$i].fetish = "cumslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "cumslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "cumslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his oral fetish.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "anal">>
 			<<if ($slaves[$i].fetish != "buttslut")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his rear hole is being fucked.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms when $his ass is being stimulated, @@.lightcoral;$he develops a fetish for being an anal bottom.@@
-					<<set $slaves[$i].fetish = "buttslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "buttslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "buttslut", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his anal fetish.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "boobs">>
 			<<if ($slaves[$i].fetish != "boobs")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $his tits are being touched.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms when $his nipples are being stimulated, @@.lightcoral;$he develops a fetish for $his tits.@@
-					<<set $slaves[$i].fetish = "boobs", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "boobs", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "boobs", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his boob fetish.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "submissive">>
 			<<if ($slaves[$i].fetish != "submissive")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being held down and used.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms when $he is restrained, @@.lightcoral;$he develops a fetish for submission.@@
-					<<set $slaves[$i].fetish = "submissive", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "submissive", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "submissive", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his submission.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "humiliation">>
 			<<if ($slaves[$i].fetish != "humiliation")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's got an audience.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms when $he is being humiliated, @@.lightcoral;$he develops a fetish for humiliation.@@
-					<<set $slaves[$i].fetish = "humiliation", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "humiliation", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "humiliation", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his humiliation fetish.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "pregnancy">>
 			<<if ($slaves[$i].fetish != "pregnancy")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he feels like $he's being bred.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms during <<if $PC.dick == 1>>unprotected sex<<if $PC.vagina == 1>> and <</if>><</if>><<if $PC.vagina == 1>>loving contact with the female anatomy<</if>>, @@.lightcoral;$he begins to fantasize about pregnancy.@@
-					<<set $slaves[$i].fetish = "pregnancy", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "pregnancy", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "pregnancy", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his pregnancy fetish.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "dom">>
 			<<if ($slaves[$i].fetish != "dom")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when another slave is servicing $him.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms while $he's taking an active, dominant sexual role, @@.lightcoral;$he begins to enjoy dominance.@@
-					<<set $slaves[$i].fetish = "dom", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "dom", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "dom", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his dominance.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "masochist">>
 			<<if ($slaves[$i].fetish != "masochist")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he's being hurt.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms while $he's being beaten, @@.lightcoral;$he begins to enjoy pain.@@
-					<<set $slaves[$i].fetish = "masochist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "masochist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "masochist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his masochism.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<<case "sadist">>
 			<<if ($slaves[$i].fetish != "sadist")>>
 				<<if $slaves[$i].fetishStrength >= 10>>
 					The bullet vibrator $he is wearing acts to @@.coral;suppress $his current fetish,@@ encouraging $him to orgasm when $he witnesses or even takes part in another slave's pain.
-					<<set $slaves[$i].fetishStrength -= 30>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 25>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetishStrength -= 30>>
+					<</if>>
 				<<elseif (_fetishChangeChance > random(0,100)-20*$assistant)>>
 					The bullet vibrator $he is wearing encourages many orgasms while $he's involved in the abuse of other slaves, @@.lightcoral;$he begins to develop a sadistic streak.@@
-					<<set $slaves[$i].fetish = "sadist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+						<<set $slaves[$i].fetish = "sadist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 15>>
+					<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+						<<set $slaves[$i].fetish = "sadist", $slaves[$i].fetishKnown = 1, $slaves[$i].fetishStrength = 20>>
+					<</if>>
 				<</if>>
 			<<elseif ($slaves[$i].fetishStrength <= 95)>>
 				The bullet vibrator $he is wearing @@.lightcoral;advances $his sadism.@@
-				<<set $slaves[$i].fetishStrength += 6>>
+				<<if _vAcc == "bullet vibrator" || _dAcc == "bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 6>>
+				<<elseif _vAcc == "smart bullet vibrator" || _dAcc == "smart bullet vibrator">>
+					<<set $slaves[$i].fetishStrength += 8>>
+				<</if>>
 			<</if>>
 		<</switch>>
 	<</if>>
diff --git a/src/uncategorized/seBirth.tw b/src/uncategorized/seBirth.tw
index caaadf74ce28e957bc12f141302666863bd93c2f..c252a44894e4e6118d503ab4de4ef8d88f2a1ac8 100644
--- a/src/uncategorized/seBirth.tw
+++ b/src/uncategorized/seBirth.tw
@@ -115,7 +115,7 @@ I need to break single passage to several widgets, as it's been overcomplicated
 							For a moment, $he saw a glimmer of good in you; @@.mediumorchid;$he was clearly wrong.@@ $His mind struggles to comprehend @@.gold;why $he could ever even thing of trusting such a person.@@
 							<<set $slaves[$i].trust -= 30, $slaves[$i].devotion -= 30>>
 						<</if>>
-						<<set $cash += _curBabies*(50+_babyCost)>>
+						<<run cashX(_curBabies*(50+_babyCost), "babyTransfer")>>
 				<</switch>>
 			<</if>>
 			<<seBirthPostpartum>>
diff --git a/src/uncategorized/slaveInteract.tw b/src/uncategorized/slaveInteract.tw
index d6c351fe2e170df9329a3f2979a26acd1674b83c..0e5d8a4045907af200018ef2777affa7abc6ef28 100644
--- a/src/uncategorized/slaveInteract.tw
+++ b/src/uncategorized/slaveInteract.tw
@@ -1059,6 +1059,9 @@
 		<<if isItemAccessible("bullet vibrator")>>
 			| <<link "Bullet vibrator">><<set $activeSlave.vaginalAccessory = "bullet vibrator">><<replace "#vaginalAccessory">>$activeSlave.vaginalAccessory<</replace>><</link>>
 		<</if>>
+		<<if isItemAccessible("smart bullet vibrator") && $toysBoughtSmartVibes == 1>>
+			| <<link "Smart bullet vibrator">><<set $activeSlave.vaginalAccessory = "smart bullet vibrator">><<replace "#vaginalAccessory">>$activeSlave.vaginalAccessory<</replace>><</link>>
+		<</if>>
 		| <<link "Dildo">><<set $activeSlave.vaginalAccessory = "dildo">><<replace "#vaginalAccessory">>$activeSlave.vaginalAccessory<</replace>><</link>>
 		<<if isItemAccessible("long dildo") && ($activeSlave.breedingMark != 1 || $propOutcome == 0)>>
 			| <<link "Long dildo">><<set $activeSlave.vaginalAccessory = "long dildo">><<replace "#vaginalAccessory">>$activeSlave.vaginalAccessory<</replace>><</link>>
@@ -1073,7 +1076,7 @@
 				| <<link "Huge and long dildo">><<set $activeSlave.vaginalAccessory = "long, huge dildo">><<replace "#vaginalAccessory">>$activeSlave.vaginalAccessory<</replace>><</link>>
 			<</if>>
 		<</if>>
-		<<if isItemAccessible("vibrator") && $activeSlave.vaginalAccessory != "none" && $activeSlave.vaginalAccessory != "bullet vibrator" && $toysBoughtVaginalAttachments == 1>>
+		<<if isItemAccessible("vibrator") && ($activeSlave.vaginalAccessory != "none" && $activeSlave.vaginalAccessory != "bullet vibrator" && $activeSlave.vaginalAccessory != "smart bullet vibrator") && $toysBoughtVaginalAttachments == 1>>
 			<br>
 			&nbsp;&nbsp;&nbsp;&nbsp;Vaginal accessory attachment:
 			''<span id="vaginalAttachment">$activeSlave.vaginalAttachment</span>.''
@@ -1086,7 +1089,10 @@
 		<br>Dick accessory: ''<span id="dickAccessory">$activeSlave.dickAccessory</span>.''
 		<<link "None">><<set $activeSlave.dickAccessory = "none">><<replace "#dickAccessory">>$activeSlave.dickAccessory<</replace>><<SlaveInteractSexOption>><<SlaveInteractAnalSexOption>><<SlaveInteractGropeOption>><<SlaveInteractDickGropeOption>><<SlaveInteractAnalGropeOption>><</link>>
 		<<if isItemAccessible("bullet vibrator") && $toysBoughtVaginalAttachments == 1>>
-			<<link "Bullet vibrator">><<set $activeSlave.dickAccessory = "bullet vibrator">><<replace "#dickAccessory">>$activeSlave.dickAccessory<</replace>><</link>>
+			| <<link "Bullet vibrator">><<set $activeSlave.dickAccessory = "bullet vibrator">><<replace "#dickAccessory">>$activeSlave.dickAccessory<</replace>><</link>>
+		<</if>>
+		<<if isItemAccessible("smart bullet vibrator") && $toysBoughtVaginalAttachments == 1>>
+			| <<link "Smart bullet vibrator">><<set $activeSlave.dickAccessory = "smart bullet vibrator">><<replace "#dickAccessory">>$activeSlave.dickAccessory<</replace>><</link>>
 		<</if>>
 	<</if>>
 
@@ -1660,7 +1666,7 @@ Hormones: <strong><span id="hormones">
 	<</if>>
 <</if>>
 
-<<if $activeSlave.clitPiercing == 3 || $activeSlave.vaginalAccessory == "bullet vibrator">>
+<<if $activeSlave.clitPiercing == 3 || $activeSlave.vaginalAccessory == "smart bullet vibrator">>
 	<br>&nbsp;&nbsp;&nbsp;&nbsp;
 	<<if $activeSlave.clitPiercing == 3>>
 		<<if $activeSlave.dick < 1>>
@@ -1669,7 +1675,7 @@ Hormones: <strong><span id="hormones">
 			$His smart frenulum piercing is set to
 		<</if>>
 	<<else>>
-		$His bullet vibe is set to
+		$His smart bullet vibe is set to
 	<</if>>
 	<strong><span id="setting">$activeSlave.clitSetting</span></strong>.
 	<<link "Vanilla">><<set $activeSlave.clitSetting = "vanilla">><<replace "#setting">>$activeSlave.clitSetting<</replace>><</link>>
diff --git a/src/uncategorized/wardrobe.tw b/src/uncategorized/wardrobe.tw
index 25efda9a2099680bea974b19f7db29e8badea995..75d610cad31f7b55d50be18133a5f30eed8eaadf 100644
--- a/src/uncategorized/wardrobe.tw
+++ b/src/uncategorized/wardrobe.tw
@@ -269,18 +269,25 @@ The room containing all the clothes and accessories you have available to dress
 
 <br><br>
 <<if $toysBoughtDildos == 0>>
-	[[Order a shipment of extra long dildos|Wardrobe][cashX(forceNeg(Math.trunc(10000 * $upgradeMultiplierTrade)), "capEx"), $toysBoughtDildos = 1]]
+	[[Order a shipment of extra long dildos and bullet vibes|Wardrobe][cashX(forceNeg(Math.trunc(10000 * $upgradeMultiplierTrade)), "capEx"), $toysBoughtDildos = 1]]
 	//Costs <<print cashFormat(Math.trunc(10000 * $upgradeMultiplierTrade))>>//
 <<else>>
-	You are well stocked with extra long dildos in a variety of sizes.
+	You are well stocked with extra long dildos in a variety of sizes, as well as a good amount of bullet vibrators.	/* FIXME: not happy with this line */
+	<<if $toysBoughtSmartVibes == 0>>
+		<br>
+		&nbsp;&nbsp;&nbsp;&nbsp;[[Order the "smart" variant of the bullet vibrators|Wardrobe][cashX(forceNeg(Math.trunc(5000 * $upgradeMultiplierTrade)), "capEx"), $toysBoughtSmartVibes = 1]]
+		//Costs <<print cashFormat(Math.trunc(5000 * $upgradeMultiplierTrade))>>//
+	<<else>>
+		Some of the bullet vibes are of the "smart" variety.
+	<</if>>
 <</if>>
 
 <br>
 <<if $toysBoughtVaginalAttachments == 0>>
-	[[Order a shipment of bullet vibes and vibrating dildos|Wardrobe][cashX(forceNeg(Math.trunc(10000 * $upgradeMultiplierTrade)), "capEx"), $toysBoughtVaginalAttachments = 1]]
+	[[Order a shipment of vibrating dildo attachments|Wardrobe][cashX(forceNeg(Math.trunc(10000 * $upgradeMultiplierTrade)), "capEx"), $toysBoughtVaginalAttachments = 1]]
 	//Costs <<print cashFormat(Math.trunc(10000 * $upgradeMultiplierTrade))>>//
 <<else>>
-	You are well stocked with bullet vibrators and vibrating dildos.
+	You are well stocked with attachments that allow dildos to vibrate.
 <</if>>
 
 <br>
diff --git a/src/uncategorized/wardrobeUse.tw b/src/uncategorized/wardrobeUse.tw
index 5b3665397bd19fff3cef081ac45f5acf4d625060..62d97e650f2bc122b556fb46bdd5b1c40b5af2aa 100644
--- a/src/uncategorized/wardrobeUse.tw
+++ b/src/uncategorized/wardrobeUse.tw
@@ -1116,6 +1116,14 @@ Clothes: ''<span id="clothes">$activeSlave.clothes</span>.''
 			<<replace "#buttplugDescription">>//<<buttplugDescription>>//<</replace>>
 		<</link>>
 	<</if>>
+	<<if isItemAccessible("smart bullet vibrator")>>
+		| <<link "Smart bullet vibrator">>
+			<<set $activeSlave.vaginalAccessory = "smart bullet vibrator">>
+			<<replace "#vaginalAccessory">>$activeSlave.vaginalAccessory<</replace>>
+			<<replace "#vaginalAccessoryDescription">>//<<vaginalAccessoryDescription>>//<</replace>>
+			<<replace "#buttplugDescription">>//<<buttplugDescription>>//<</replace>>
+		<</link>>
+	<</if>>
 	| <<link "Dildo">>
 		<<set $activeSlave.vaginalAccessory = "dildo">>
 		<<replace "#vaginalAccessory">>$activeSlave.vaginalAccessory<</replace>>
@@ -1160,7 +1168,7 @@ Clothes: ''<span id="clothes">$activeSlave.clothes</span>.''
 			<</link>>
 		<</if>>
 	<</if>>
-	<<if isItemAccessible("vibrator") && $activeSlave.vaginalAccessory != "none" && $activeSlave.vaginalAccessory != "bullet vibrator" && $toysBoughtVaginalAttachments == 1>>
+	<<if isItemAccessible("vibrator") && $activeSlave.vaginalAccessory != "none" && ($activeSlave.vaginalAccessory != "bullet vibrator" && $activeSlave.vaginalAccessory != "smart bullet vibrator") && $toysBoughtVaginalAttachments == 1>>
 		<br><br>
 		Vaginal accessory attachment:
 		''<span id="vaginalAttachment">$activeSlave.vaginalAttachment</span>.''
@@ -1201,6 +1209,14 @@ Clothes: ''<span id="clothes">$activeSlave.clothes</span>.''
 			<<replace "#dickAccessoryDescription">>//<<dickAccessoryDescription>>//<</replace>>
 			<<replace "#buttplugDescription">>//<<buttplugDescription>>//<</replace>>
 		<</link>>
+		<<if isItemAccessible("smart bullet vibrator") && $toysBoughtSmartVibes == 1>>
+			| <<link "Smart bullet vibrator">>
+				<<set $activeSlave.dickAccessory = "smart bullet vibrator">>
+				<<replace "#dickAccessory">>$activeSlave.dickAccessory<</replace>>
+				<<replace "#dickAccessoryDescription">>//<<dickAccessoryDescription>>//<</replace>>
+				<<replace "#buttplugDescription">>//<<buttplugDescription>>//<</replace>>
+			<</link>>
+		<</if>>
 	<</if>>
 <</if>>
 <br><br>
diff --git a/src/utility/descriptionWidgetsFlesh.tw b/src/utility/descriptionWidgetsFlesh.tw
index 4b77874946061c2073b80d101808b4c25c963455..5507d047247a50df7fa5e98b0efc2abb78638a3f 100644
--- a/src/utility/descriptionWidgetsFlesh.tw
+++ b/src/utility/descriptionWidgetsFlesh.tw
@@ -3656,7 +3656,7 @@ $He's got a
 			<<if ($activeSlave.dick > 0) && ($activeSlave.vagina > -1)>>
 				$activeSlave.slaveName's sackcloth undergarments chafe and torture $his poor hermaphrodite's genitalia, keeping $his aware that $he is an abomination.
 			<<elseif $activeSlave.dick > 0>>
-				$He's wearing a painful metal cilice around the base of $his cock, making $his shift constantly in search of comfort that will not come.
+				$He's wearing a painful metal cilice around the base of $his cock, making $him shift constantly in search of comfort that will not come.
 			<<elseif $activeSlave.vagina == -1>>
 				$activeSlave.slaveName's sackcloth undergarments chafe and torture $his poor, featureless groin.
 			<<else>>
@@ -7373,7 +7373,7 @@ $He has
 				<<if $activeSlave.bellyAccessory == "a small empathy belly">>
 					$activeSlave.slaveName's small pregnant belly comfortably rounds out $his corset.
 				<<elseif $activeSlave.bellyFluid >= $activeSlave.bellyPreg && $activeSlave.bellyFluid >= $activeSlave.bellyImplant>>
-					$activeSlave.slaveName's <<print $activeSlave.inflationType>>-swollen belly is lightly compressed by $his corset making $his uncomfortable.
+					$activeSlave.slaveName's <<print $activeSlave.inflationType>>-swollen belly is lightly compressed by $his corset making $him uncomfortable.
 				<<elseif $activeSlave.bellyImplant > 0>>
 					$activeSlave.slaveName's implant-rounded belly comfortably rounds out $his corset.
 				<<else>>
@@ -14756,11 +14756,11 @@ $He has
 				<<if $activeSlave.bellyAccessory == "a large empathy belly">>
 					$activeSlave.slaveName's belt is struggling to fully encircle $his big pregnant belly.
 				<<elseif $activeSlave.bellyFluid >= $activeSlave.bellyPreg && $activeSlave.bellyFluid >= $activeSlave.bellyImplant>>
-					$activeSlave.slaveName's belt is struggling to fully encircle $$his hugely <<print $activeSlave.inflationType>>-swollen belly.
+					$activeSlave.slaveName's belt is struggling to fully encircle $his hugely <<print $activeSlave.inflationType>>-swollen belly.
 				<<elseif $activeSlave.bellyImplant > 0>>
-					$activeSlave.slaveName's belt is struggling to fully encircle $$his huge implant-filled belly.
+					$activeSlave.slaveName's belt is struggling to fully encircle $his huge implant-filled belly.
 				<<else>>
-					$activeSlave.slaveName's belt is struggling to fully encircle $$his big pregnant belly.
+					$activeSlave.slaveName's belt is struggling to fully encircle $his big pregnant belly.
 				<</if>>
 			<<elseif $activeSlave.weight > 160>>
 				$activeSlave.slaveName's hugely fat belly accentuates the design of and badly stretches out $his festive dress.
@@ -17973,7 +17973,7 @@ $He has
 			<<if ($activeSlave.physicalAge - $activeSlave.visualAge <= 5)>>
 				not really begun to youthen $his appearance yet.
 			<<elseif ($activeSlave.physicalAge - $activeSlave.visualAge <= 10)>>
-				clearly been at work on $him, making $his appear younger.
+				clearly been at work on $him, making $him appear younger.
 			<<elseif ($activeSlave.physicalAge -$activeSlave.visualAge <= 20)>>
 				obviously helped take more than a decade off of $his age.
 			<<else>>
@@ -18773,6 +18773,12 @@ $He has
 				$activeSlave.slaveName's tight leotard shows off every <<if $showInches == 2>>inch<<else>>centimeter<</if>> of $his titanic implant-filled belly. $His immense stomach slightly protrudes from the various rips and tears that have begun appearing in the fabric.
 			<<case "a monokini">>
 				$activeSlave.slaveName's titanic implant-filled belly has pushed down the front of $his monokini, leaving $his belly mostly bare.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's gigantic breasts push out $his overalls so far that $his huge implant-filled belly is left halfway uncovered.
+				<<else>>
+					The front of $activeSlave.slaveName's overalls barely covers half of $his huge implant-filled pregnant belly.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName has given up trying to tie $his apron's strings, allowing the frilly garment to idly rest upon $his titanic implant-filled belly.
 			<<case "a cybersuit">>
@@ -18987,6 +18993,12 @@ $He has
 				$activeSlave.slaveName's tight leotard shows off every kick and movement within $his gigantic implant-filled belly. The material tightly clings to $his popped navel and strains to hold together.
 			<<case "a monokini">>
 				$activeSlave.slaveName's gigantic implant-filled belly pushes the fabric of $his monokini to below $his popped navel.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's enormous breasts push out $his overalls so far that $his huge implant-filled belly is left mostly uncovered.
+				<<else>>
+					$activeSlave.slaveName's overalls are pulled taut by $his huge implant-filled belly.
+				<</if>>
 			<<case "an apron">>
 				The strings of $activeSlave.slaveName's apron struggle to stay tied due to the size of $his huge implant-filled belly.
 			<<case "a cybersuit">>
@@ -18994,7 +19006,7 @@ $He has
 			<<case "a chattel habit">>
 				The strip of cloth running down $his front is parted to one side by $his gigantic implant-filled belly.
 			<<case "a bunny outfit">>
-				$activeSlave.slaveName's teddy has burst trying to contain $his gigantic implant-filled belly leaving it hanging out the hole it made.
+				$activeSlave.slaveName's teddy has burst trying to contain $his gigantic implant-filled belly, leaving it hanging out the hole it made.
 			<<case "spats and a tank top">>
 				<<if ($activeSlave.boobs > 1200)>>
 					$activeSlave.slaveName's top is prevented from trying to cover $his gigantic implant-filled belly by $his breasts.
@@ -19183,7 +19195,7 @@ $He has
 			<<case "a button-up shirt and panties" "a button-up shirt" "a t-shirt" "a t-shirt and thong" "an oversized t-shirt and boyshorts" "an oversized t-shirt" "sport shorts and a t-shirt" "a t-shirt and jeans" "a t-shirt and panties">>
 				$activeSlave.slaveName's shirt is noticeably rounded out by $his huge implant-filled belly.
 			<<case "a Santa dress">>
-				$activeSlave.slaveName's belt is struggling to fully encircle $$his huge implant-filled belly.
+				$activeSlave.slaveName's belt is struggling to fully encircle $his huge implant-filled belly.
 			<<case "a burkini">>
 				The fabric of $activeSlave.slaveName's burkini is slightly pushed up thanks to $his huge implant-filled belly.
 			<<case "a hijab and blouse">>
@@ -19200,6 +19212,12 @@ $He has
 				$activeSlave.slaveName's tight leotard shows off every kick and movement within $his huge implant-filled belly. The material tightly clings to $his popped navel.
 			<<case "a monokini">>
 				$activeSlave.slaveName's huge implant-filled belly pushes the fabric of $his monokini to rest just above $his popped navel.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's massive breasts push out $his overalls so far that $his hugely swollen belly is left almost entirely uncovered.
+				<<else>>
+					$activeSlave.slaveName's hugely swollen belly stretches out the fabric of $his overalls.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName's apron is pushed away from $his body by $his huge implant-filled belly.
 			<<case "a cybersuit">>
@@ -19414,6 +19432,12 @@ $He has
 				$activeSlave.slaveName's tight leotard shows off every kick and movement within $his implant-filled belly. The material tightly clings to $his popped navel.
 			<<case "a monokini">>
 				$activeSlave.slaveName's implant-filled belly pushes down the fabric of $his monokini down somewhat.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's huge breasts push out $his overalls so far that $his implant-filled belly is left uncovered.
+				<<else>>
+					$activeSlave.slaveName's overalls are significantly curved by $his implant-filled belly.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName's apron is filled out by $his implant-filled belly.
 			<<case "a cybersuit">>
@@ -19630,6 +19654,12 @@ $He has
 				$activeSlave.slaveName's tight leotard tightly clings to $his fat belly, clearly displaying every fold and roll.
 			<<case "a monokini">>
 				$activeSlave.slaveName's monokini tightly clings to $his fat belly, clearly displaying every fold and roll.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's large breasts push out $his overalls so far that $his fat belly is left uncovered.
+				<<else>>
+					$activeSlave.slaveName's fat belly bulges out from over the sides of $his overalls.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName's mini dress tightly clings to $his fat belly, clearly showing every fold and roll.
 			<<case "a cybersuit">>
@@ -19805,27 +19835,27 @@ $He has
 			<<case "a hijab and abaya" "a niqab and abaya">>
 				$activeSlave.slaveName's abaya bulges with $his implant-rounded belly.
 			<<case "a klan robe">>
-				$activeSlave.slaveName's robe is filled out by $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's robe is filled out by $his implant-swollen belly.
 			<<case "a burqa">>
-				$activeSlave.slaveName's burqa is filled out by $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's burqa is filled out by $his implant-swollen belly.
 			<<case "a nice pony outfit" "a slutty pony outfit">>
-				$activeSlave.slaveName's pony outfit is rounded out by $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's pony outfit is rounded out by $his implant-swollen belly.
 			<<case "a tube top and thong" "a bra" "a thong" "a tube top" "a striped bra" "striped underwear" "a skimpy loincloth" "a slutty klan robe" "a sports bra" "boyshorts" "cutoffs" "leather pants and pasties" "leather pants" "panties" "panties and pasties" "sport shorts and a sports bra" "jeans" "leather pants and a tube top" "sport shorts">>
-				$activeSlave.slaveName's outfit completely bares $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's outfit completely bares $his implant-swollen belly.
 			<<case "a one-piece swimsuit">>
-				$activeSlave.slaveName's swimsuit is rounded out by $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's swimsuit is rounded out by $his implant-swollen belly.
 			<<case "a sweater" "a sweater and cutoffs" "a sweater and panties">>
-				$activeSlave.slaveName's sweater is rounded out by $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's sweater is rounded out by $his implant-swollen belly.
 			<<case "a police uniform">>
-				$activeSlave.slaveName's uniform is rounded out by $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's uniform is rounded out by $his implant-swollen belly.
 			<<case "a hanbok">>
-				$activeSlave.slaveName's hanbok gently bulges from $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's hanbok gently bulges from $his implant-swollen belly.
 			<<case "a gothic lolita dress">>
-				$activeSlave.slaveName's dress gently bulges from $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's dress gently bulges from $his implant-swollen belly.
 			<<case "a tank-top" "a tank-top and panties">>
-				$activeSlave.slaveName's tank-top gently bulges from $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's tank-top gently bulges from $his implant-swollen belly.
 			<<case "a button-up shirt and panties" "a button-up shirt" "a t-shirt" "a t-shirt and thong" "an oversized t-shirt and boyshorts" "an oversized t-shirt" "sport shorts and a t-shirt" "a t-shirt and jeans" "a t-shirt and panties">>
-				$activeSlave.slaveName's shirt covers most of $his <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's shirt covers most of $his implant-swollen belly.
 			<<case "a Santa dress">>
 				The belt of $activeSlave.slaveName's dress lies atop the gentle bulge of $his implant-rounded belly.
 			<<case "a burkini">>
@@ -19844,6 +19874,12 @@ $He has
 				$activeSlave.slaveName's tight leotard shows off $his implant-rounded belly.
 			<<case "a monokini">>
 				$activeSlave.slaveName's monokini is filled out by $his implant-rounded belly.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's large breasts push out $his overalls so far that $his implant-rounded belly is left uncovered.
+				<<else>>
+					$activeSlave.slaveName's implant-rounded belly rounds out the front of $his overalls.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName's apron is rounded out by $his implant-rounded belly.
 			<<case "a cybersuit">>
@@ -20287,7 +20323,7 @@ $He has
 			<<case "a button-up shirt and panties" "a button-up shirt" "a t-shirt" "a t-shirt and thong" "an oversized t-shirt and boyshorts" "an oversized t-shirt" "sport shorts and a t-shirt" "a t-shirt and jeans" "a t-shirt and panties">>
 				$activeSlave.slaveName's shirt is noticeably rounded out by $his hugely swollen belly.
 			<<case "a Santa dress">>
-				$activeSlave.slaveName's belt is struggling to fully encircle $$his hugely <<print $activeSlave.inflationType>>-swollen belly.
+				$activeSlave.slaveName's belt is struggling to fully encircle $his hugely <<print $activeSlave.inflationType>>-swollen belly.
 			<<case "a burkini">>
 				The fabric of $activeSlave.slaveName's burkini is slightly pushed up thanks to $his hugely <<print $activeSlave.inflationType>>-swollen belly.
 			<<case "a hijab and blouse">>
@@ -20304,6 +20340,12 @@ $He has
 				$activeSlave.slaveName's tight leotard shows off every slosh and jiggle within $his hugely swollen belly. The material tightly clings to $his popped navel.
 			<<case "a monokini">>
 				$activeSlave.slaveName's monokini covers far less than half of $his hugely swollen belly.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's massive breasts push out $his overalls so far that $his hugely swollen belly is left almost entirely uncovered.
+				<<else>>
+					$activeSlave.slaveName's hugely swollen belly stretches out the fabric of $his overalls.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName's apron is pushed away from $his body by $his hugely <<print $activeSlave.inflationType>>-swollen belly.
 			<<case "a cybersuit">>
@@ -20513,6 +20555,12 @@ $He has
 				$activeSlave.slaveName's tight leotard shows off every movement within $his jiggling <<print $activeSlave.inflationType>>-filled belly. The material tightly clings to $his popped navel.
 			<<case "a monokini">>
 				$activeSlave.slaveName's monokini overs only half of $his jiggling <<print $activeSlave.inflationType>>-filled belly.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's huge breasts push out $his overalls so far that $his jiggling <<print $activeSlave.inflationType>>-filled belly is left uncovered.
+				<<else>>
+					$activeSlave.slaveName's overalls are significantly curved by $his jiggling <<print $activeSlave.inflationType>>-filled belly.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName's apron is filled out by $his jiggling <<print $activeSlave.inflationType>>-filled belly.
 			<<case "a cybersuit">>
@@ -20724,6 +20772,12 @@ $He has
 				$activeSlave.slaveName's tight leotard tightly clings to $his fat belly, clearly displaying every fold and roll.
 			<<case "a monokini">>
 				$activeSlave.slaveName's monokini tightly clings to $his fat belly, clearly displaying every fold and roll.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's large breasts push out $his overalls so far that $his fat belly is left uncovered.
+				<<else>>
+					$activeSlave.slaveName's fat belly bulges out from over the sides of $his overalls.
+				<</if>>
 			<<case "an apron">>
 				$activeSlave.slaveName's mini dress tightly clings to $his fat belly, clearly showing every fold and roll.
 			<<case "a cybersuit">>
@@ -20751,7 +20805,7 @@ $He has
 			<<if ($activeSlave.bellyAccessory == "an extreme corset")>>
 				$activeSlave.slaveName's <<print $activeSlave.inflationType>>-swollen belly is tightly compressed by $his corset causing $his distress.
 			<<elseif ($activeSlave.bellyAccessory == "a corset")>>
-				$activeSlave.slaveName's <<print $activeSlave.inflationType>>-swollen belly is lightly compressed by $his corset making $his uncomfortable.
+				$activeSlave.slaveName's <<print $activeSlave.inflationType>>-swollen belly is lightly compressed by $his corset making $him uncomfortable.
 			<</if>>
 			<<switch $activeSlave.clothes>>
 			<<case "conservative clothing">>
@@ -20895,7 +20949,7 @@ $He has
 			<<case "a kimono">>
 				$activeSlave.slaveName's <<print $activeSlave.inflationType>>-swollen belly is demurely covered by $his kimono.
 			<<case "a hijab and abaya" "a niqab and abaya">>
-				$activeSlave.slaveName's abaya is filled out by $his fat belly.
+				$activeSlave.slaveName's abaya is filled out by $his <<print $activeSlave.inflationType>>-swollen belly.
 			<<case "a klan robe">>
 				$activeSlave.slaveName's robe is filled out by $his <<print $activeSlave.inflationType>>-swollen belly.
 			<<case "a burqa">>
@@ -20934,6 +20988,12 @@ $He has
 				$activeSlave.slaveName's bangles include a long thin chain that rests across $his <<print $activeSlave.inflationType>>-swollen belly.
 			<<case "a leotard">>
 				$activeSlave.slaveName's tight leotard shows off $his <<print $activeSlave.inflationType>>-swollen belly.
+			<<case "overalls">>
+				<<if ($activeSlave.boobs > ($activeSlave.belly+250))>>
+					$activeSlave.slaveName's large breasts push out $his overalls so far that $his <<print $activeSlave.inflationType>>-swollen belly is left uncovered.
+				<<else>>
+					$activeSlave.slaveName's <<print $activeSlave.inflationType>>-swollen belly rounds out the front of $his overalls.
+				<</if>>
 			<<case "a monokini">>
 				$activeSlave.slaveName's monokini covers most of $his <<print $activeSlave.inflationType>>-swollen belly.
 			<<case "an apron">>
diff --git a/src/utility/descriptionWidgetsStyle.tw b/src/utility/descriptionWidgetsStyle.tw
index cb764bf93eac0368e0649a45a748ca80aaf01294..0b0ca19826e6c0a8232ca8626e93974f8fa97282 100644
--- a/src/utility/descriptionWidgetsStyle.tw
+++ b/src/utility/descriptionWidgetsStyle.tw
@@ -5915,8 +5915,8 @@ $His
 	<</if>>
 <</if>>
 <<switch $activeSlave.vaginalAccessory>>
-<<case "bullet vibrator">>
-	/* TODO: write a description */
+<<case "bullet vibrator" "smart bullet vibrator">>	/* FIXME: two different descriptions? */
+	A bullet vibrator is attached on $his clit, held in place by a strap.	/* FIXME: not super happy with this */
 <<case "dildo">>
 	/* TODO: these may need to be updated for slaves with gaping+ vaginas */
 	$His pussy is filled by a dildo held in place by a strap, which $he can remove for vaginal intercourse.
diff --git a/src/utility/miscWidgets.tw b/src/utility/miscWidgets.tw
index e2f8e5f5ac3bed31ad9661ecccdf337d017a72ec..681062bdccf01cb13eb901fc892f19c52eb4c0a0 100644
--- a/src/utility/miscWidgets.tw
+++ b/src/utility/miscWidgets.tw
@@ -686,7 +686,7 @@ This experience
 		<<elseif def $args[1]>>
 			[[Customize the exterior of the arcology to support this goal|Future Society][$arcologies[0][_FSDecoration] = 100, State.variables[$args[1]] = 1, cashX(-20000, "capEx")]] //Costs <<print cashFormat(20000)>>//
 		<<elseif $args[0] == "FSRestart">>
-			[[Customize the exterior of the arcology to support this goal and fully establish the Societal Elite|Future Society][$arcologies[0].FSRestartDecoration = 100, $upgradeMultiplierArcology = upgradeMultiplierArcology(), $upgradeMultiplierMedicine = upgradeMultiplierMedicine(), $cash -= 75000]] //Costs <<print cashFormat(75000)>> and may dilute your control over the arcology//
+			[[Customize the exterior of the arcology to support this goal and fully establish the Societal Elite|Future Society][$arcologies[0].FSRestartDecoration = 100, $upgradeMultiplierArcology = upgradeMultiplierArcology(), $upgradeMultiplierMedicine = upgradeMultiplierMedicine(), cashX(-75000, "capEx")]] //Costs <<print cashFormat(75000)>> and may dilute your control over the arcology//
 		<<else>>
 			[[Customize the exterior of the arcology to support this goal|Future Society][$arcologies[0][_FSDecoration] = 100, cashX(-20000, "capEx")]] //Costs <<print cashFormat(20000)>>//
 		<</if>>