diff --git a/Mage.Sets/src/mage/cards/c/CurseOfClingingWebs.java b/Mage.Sets/src/mage/cards/c/CurseOfClingingWebs.java
new file mode 100644
index 0000000000..b1aff4820a
--- /dev/null
+++ b/Mage.Sets/src/mage/cards/c/CurseOfClingingWebs.java
@@ -0,0 +1,65 @@
+package mage.cards.c;
+
+import mage.abilities.Ability;
+import mage.abilities.common.DiesCreatureTriggeredAbility;
+import mage.abilities.effects.common.AttachEffect;
+import mage.abilities.effects.common.CreateTokenEffect;
+import mage.abilities.effects.common.ExileTargetEffect;
+import mage.abilities.keyword.EnchantAbility;
+import mage.cards.CardImpl;
+import mage.cards.CardSetInfo;
+import mage.constants.CardType;
+import mage.constants.Outcome;
+import mage.constants.SubType;
+import mage.filter.FilterPermanent;
+import mage.filter.common.FilterCreaturePermanent;
+import mage.filter.predicate.permanent.EnchantPlayerControlsPredicate;
+import mage.filter.predicate.permanent.TokenPredicate;
+import mage.game.permanent.token.SpiderToken;
+import mage.target.TargetPlayer;
+
+import java.util.UUID;
+
+/**
+ * @author TheElk801
+ */
+public final class CurseOfClingingWebs extends CardImpl {
+
+    private static final FilterPermanent filter
+            = new FilterCreaturePermanent("a nontoken creature enchanted player controls");
+
+    static {
+        filter.add(TokenPredicate.FALSE);
+        filter.add(EnchantPlayerControlsPredicate.instance);
+    }
+
+    public CurseOfClingingWebs(UUID ownerId, CardSetInfo setInfo) {
+        super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{2}{G}");
+
+        this.subtype.add(SubType.AURA);
+        this.subtype.add(SubType.CURSE);
+
+        // Enchant player
+        TargetPlayer auraTarget = new TargetPlayer();
+        this.getSpellAbility().addTarget(auraTarget);
+        this.getSpellAbility().addEffect(new AttachEffect(Outcome.BoostCreature));
+        this.addAbility(new EnchantAbility(auraTarget.getTargetName()));
+
+        // Whenever a nontoken creature enchanted player controls dies, exile it and you create a 1/2 green Spider creature token with reach.
+        Ability ability = new DiesCreatureTriggeredAbility(
+                new ExileTargetEffect().setText("exile it"),
+                false, filter, true
+        );
+        ability.addEffect(new CreateTokenEffect(new SpiderToken()).concatBy("and you"));
+        this.addAbility(ability);
+    }
+
+    private CurseOfClingingWebs(final CurseOfClingingWebs card) {
+        super(card);
+    }
+
+    @Override
+    public CurseOfClingingWebs copy() {
+        return new CurseOfClingingWebs(this);
+    }
+}
diff --git a/Mage.Sets/src/mage/cards/c/CurseOfDeathsHold.java b/Mage.Sets/src/mage/cards/c/CurseOfDeathsHold.java
index 48b612e216..d1fe0ed60d 100644
--- a/Mage.Sets/src/mage/cards/c/CurseOfDeathsHold.java
+++ b/Mage.Sets/src/mage/cards/c/CurseOfDeathsHold.java
@@ -1,28 +1,33 @@
-
 package mage.cards.c;
 
-import mage.abilities.Ability;
 import mage.abilities.common.SimpleStaticAbility;
-import mage.abilities.effects.ContinuousEffectImpl;
 import mage.abilities.effects.common.AttachEffect;
+import mage.abilities.effects.common.continuous.BoostAllEffect;
 import mage.abilities.keyword.EnchantAbility;
 import mage.cards.CardImpl;
 import mage.cards.CardSetInfo;
-import mage.constants.*;
-import mage.filter.StaticFilters;
-import mage.game.Game;
-import mage.game.permanent.Permanent;
-import mage.players.Player;
+import mage.constants.CardType;
+import mage.constants.Duration;
+import mage.constants.Outcome;
+import mage.constants.SubType;
+import mage.filter.common.FilterCreaturePermanent;
+import mage.filter.predicate.permanent.EnchantPlayerControlsPredicate;
 import mage.target.TargetPlayer;
 
 import java.util.UUID;
 
 /**
- *
  * @author BetaSteward
  */
 public final class CurseOfDeathsHold extends CardImpl {
 
+    private static final FilterCreaturePermanent filter
+            = new FilterCreaturePermanent("creatures enchanted player controls");
+
+    static {
+        filter.add(EnchantPlayerControlsPredicate.instance);
+    }
+
     public CurseOfDeathsHold(UUID ownerId, CardSetInfo setInfo) {
         super(ownerId, setInfo, new CardType[]{CardType.ENCHANTMENT}, "{3}{B}{B}");
         this.subtype.add(SubType.AURA, SubType.CURSE);
@@ -34,7 +39,9 @@ public final class CurseOfDeathsHold extends CardImpl {
         this.addAbility(new EnchantAbility(auraTarget.getTargetName()));
 
         // Creatures enchanted player controls get -1/-1.
-        this.addAbility(new SimpleStaticAbility(Zone.BATTLEFIELD, new CurseOfDeathsHoldEffect()));
+        this.addAbility(new SimpleStaticAbility(new BoostAllEffect(
+                -1, -1, Duration.WhileOnBattlefield, filter, false
+        )));
     }
 
     private CurseOfDeathsHold(final CurseOfDeathsHold card) {
@@ -46,36 +53,3 @@ public final class CurseOfDeathsHold extends CardImpl {
         return new CurseOfDeathsHold(this);
     }
 }
-
-class CurseOfDeathsHoldEffect extends ContinuousEffectImpl {
-
-    public CurseOfDeathsHoldEffect() {
-        super(Duration.WhileOnBattlefield, Layer.PTChangingEffects_7, SubLayer.ModifyPT_7c, Outcome.UnboostCreature);
-        staticText = "Creatures enchanted player controls get -1/-1";
-    }
-
-    public CurseOfDeathsHoldEffect(final CurseOfDeathsHoldEffect effect) {
-        super(effect);
-    }
-
-    @Override
-    public boolean apply(Game game, Ability source) {
-        Permanent enchantment = game.getPermanent(source.getSourceId());
-        if (enchantment != null && enchantment.getAttachedTo() != null) {
-            Player player = game.getPlayer(enchantment.getAttachedTo());
-            if (player != null) {
-                for (Permanent perm : game.getBattlefield().getAllActivePermanents(StaticFilters.FILTER_PERMANENT_CREATURE, player.getId(), game)) {
-                    perm.addPower(-1);
-                    perm.addToughness(-1);
-                }
-                return true;
-            }
-        }
-        return false;
-    }
-
-    @Override
-    public CurseOfDeathsHoldEffect copy() {
-        return new CurseOfDeathsHoldEffect(this);
-    }
-}
diff --git a/Mage.Sets/src/mage/sets/MidnightHuntCommander.java b/Mage.Sets/src/mage/sets/MidnightHuntCommander.java
index a6590be089..be1a463bc9 100644
--- a/Mage.Sets/src/mage/sets/MidnightHuntCommander.java
+++ b/Mage.Sets/src/mage/sets/MidnightHuntCommander.java
@@ -48,6 +48,7 @@ public final class MidnightHuntCommander extends ExpansionSet {
         cards.add(new SetCardInfo("Commander's Sphere", 159, Rarity.COMMON, mage.cards.c.CommandersSphere.class));
         cards.add(new SetCardInfo("Corpse Augur", 109, Rarity.UNCOMMON, mage.cards.c.CorpseAugur.class));
         cards.add(new SetCardInfo("Crowded Crypt", 17, Rarity.RARE, mage.cards.c.CrowdedCrypt.class));
+        cards.add(new SetCardInfo("Curse of Clinging Webs", 25, Rarity.RARE, mage.cards.c.CurseOfClingingWebs.class));
         cards.add(new SetCardInfo("Custodi Soulbinders", 83, Rarity.RARE, mage.cards.c.CustodiSoulbinders.class));
         cards.add(new SetCardInfo("Dark Salvation", 110, Rarity.RARE, mage.cards.d.DarkSalvation.class));
         cards.add(new SetCardInfo("Darkwater Catacombs", 171, Rarity.RARE, mage.cards.d.DarkwaterCatacombs.class));
diff --git a/Mage/src/main/java/mage/filter/predicate/permanent/EnchantPlayerControlsPredicate.java b/Mage/src/main/java/mage/filter/predicate/permanent/EnchantPlayerControlsPredicate.java
new file mode 100644
index 0000000000..d0086b1fbb
--- /dev/null
+++ b/Mage/src/main/java/mage/filter/predicate/permanent/EnchantPlayerControlsPredicate.java
@@ -0,0 +1,19 @@
+package mage.filter.predicate.permanent;
+
+import mage.filter.predicate.ObjectSourcePlayer;
+import mage.filter.predicate.ObjectSourcePlayerPredicate;
+import mage.game.Game;
+import mage.game.permanent.Permanent;
+
+/**
+ * @author TheElk801
+ */
+public enum EnchantPlayerControlsPredicate implements ObjectSourcePlayerPredicate<ObjectSourcePlayer<Permanent>> {
+    instance;
+
+    @Override
+    public boolean apply(ObjectSourcePlayer<Permanent> input, Game game) {
+        Permanent permanent = game.getPermanent(input.getSourceId());
+        return permanent != null && input.getObject().isControlledBy(permanent.getAttachedTo());
+    }
+}