diff --git a/Mage.Sets/src/mage/cards/o/OscorpIndustries.java b/Mage.Sets/src/mage/cards/o/OscorpIndustries.java
new file mode 100644
index 00000000000..f694701108b
--- /dev/null
+++ b/Mage.Sets/src/mage/cards/o/OscorpIndustries.java
@@ -0,0 +1,50 @@
+package mage.cards.o;
+
+import mage.abilities.common.EntersBattlefieldFromGraveyardTriggeredAbility;
+import mage.abilities.common.EntersBattlefieldTappedAbility;
+import mage.abilities.effects.common.LoseLifeSourceControllerEffect;
+import mage.abilities.keyword.MayhemLandAbility;
+import mage.abilities.mana.BlackManaAbility;
+import mage.abilities.mana.BlueManaAbility;
+import mage.abilities.mana.RedManaAbility;
+import mage.cards.CardImpl;
+import mage.cards.CardSetInfo;
+import mage.constants.CardType;
+
+import java.util.UUID;
+
+/**
+ *
+ * @author Jmlundeen
+ */
+public final class OscorpIndustries extends CardImpl {
+
+ public OscorpIndustries(UUID ownerId, CardSetInfo setInfo) {
+ super(ownerId, setInfo, new CardType[]{CardType.LAND}, "");
+
+
+ // This land enters tapped.
+ this.addAbility(new EntersBattlefieldTappedAbility());
+
+ // When this land enters from a graveyard, you lose 2 life.
+ this.addAbility(new EntersBattlefieldFromGraveyardTriggeredAbility(new LoseLifeSourceControllerEffect(2)));
+
+ // {T}: Add {U}, {B}, or {R}.
+ this.addAbility(new BlueManaAbility());
+ this.addAbility(new BlackManaAbility());
+ this.addAbility(new RedManaAbility());
+
+ // Mayhem
+ this.addAbility(new MayhemLandAbility(this));
+
+ }
+
+ private OscorpIndustries(final OscorpIndustries card) {
+ super(card);
+ }
+
+ @Override
+ public OscorpIndustries copy() {
+ return new OscorpIndustries(this);
+ }
+}
diff --git a/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java b/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java
index 2b509084c9f..11e1b76b8f3 100644
--- a/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java
+++ b/Mage.Sets/src/mage/sets/MarvelsSpiderMan.java
@@ -117,6 +117,7 @@ public final class MarvelsSpiderMan extends ExpansionSet {
cards.add(new SetCardInfo("Ominous Asylum", 181, Rarity.COMMON, mage.cards.o.OminousAsylum.class));
cards.add(new SetCardInfo("Origin of Spider-Man", 218, Rarity.RARE, mage.cards.o.OriginOfSpiderMan.class, FULL_ART_USE_VARIOUS));
cards.add(new SetCardInfo("Origin of Spider-Man", 9, Rarity.RARE, mage.cards.o.OriginOfSpiderMan.class, NON_FULL_USE_VARIOUS));
+ cards.add(new SetCardInfo("Oscorp Industries", 182, Rarity.RARE, mage.cards.o.OscorpIndustries.class));
cards.add(new SetCardInfo("Oscorp Research Team", 40, Rarity.COMMON, mage.cards.o.OscorpResearchTeam.class));
cards.add(new SetCardInfo("Peter Parker", 10, Rarity.MYTHIC, mage.cards.p.PeterParker.class, NON_FULL_USE_VARIOUS));
cards.add(new SetCardInfo("Peter Parker", 208, Rarity.MYTHIC, mage.cards.p.PeterParker.class, NON_FULL_USE_VARIOUS));
diff --git a/Mage.Tests/src/test/java/org/mage/test/cards/single/spm/OscorpIndustriesTest.java b/Mage.Tests/src/test/java/org/mage/test/cards/single/spm/OscorpIndustriesTest.java
new file mode 100644
index 00000000000..6959dcce4bb
--- /dev/null
+++ b/Mage.Tests/src/test/java/org/mage/test/cards/single/spm/OscorpIndustriesTest.java
@@ -0,0 +1,52 @@
+package org.mage.test.cards.single.spm;
+
+import mage.constants.PhaseStep;
+import mage.constants.Zone;
+import org.junit.Test;
+import org.mage.test.serverside.base.CardTestPlayerBase;
+
+/**
+ *
+ * @author Jmlundeen
+ */
+public class OscorpIndustriesTest extends CardTestPlayerBase {
+
+ /*
+ Oscorp Industries
+
+ Land
+ This land enters tapped.
+ When this land enters from a graveyard, you lose 2 life.
+ {T}: Add {U}, {B}, or {R}.
+ Mayhem
+ */
+ private static final String oscorpIndustries = "Oscorp Industries";
+
+ /*
+ Thought Courier
+ {1}{U}
+ Creature - Human Wizard
+ {tap}: Draw a card, then discard a card.
+ 1/1
+ */
+ private static final String thoughtCourier = "Thought Courier";
+
+ @Test
+ public void testOscorpIndustries() {
+ setStrictChooseMode(true);
+
+ addCard(Zone.HAND, playerA, oscorpIndustries);
+ addCard(Zone.BATTLEFIELD, playerA, thoughtCourier);
+
+ activateAbility(1, PhaseStep.PRECOMBAT_MAIN, playerA, "{T}: Draw");
+ setChoice(playerA, oscorpIndustries);
+
+ playLand(1, PhaseStep.POSTCOMBAT_MAIN, playerA, oscorpIndustries + " with mayhem");
+
+ setStopAt(1, PhaseStep.END_TURN);
+ execute();
+
+ assertLife(playerA, 20 - 2);
+ assertPermanentCount(playerA, oscorpIndustries, 1);
+ }
+}
\ No newline at end of file
diff --git a/Mage/src/main/java/mage/abilities/keyword/MayhemLandAbility.java b/Mage/src/main/java/mage/abilities/keyword/MayhemLandAbility.java
new file mode 100644
index 00000000000..14c5d962023
--- /dev/null
+++ b/Mage/src/main/java/mage/abilities/keyword/MayhemLandAbility.java
@@ -0,0 +1,60 @@
+package mage.abilities.keyword;
+
+import mage.MageIdentifier;
+import mage.abilities.PlayLandAbility;
+import mage.cards.Card;
+import mage.constants.Zone;
+import mage.game.Game;
+
+import java.util.Set;
+import java.util.UUID;
+
+public class MayhemLandAbility extends PlayLandAbility {
+
+ private final String rule;
+
+ public MayhemLandAbility(Card card) {
+ super(card.getName());
+ this.zone = Zone.GRAVEYARD;
+ this.newId();
+ this.name += " with Mayhem";
+ this.addWatcher(new MayhemWatcher());
+ this.setRuleAtTheTop(true);
+ this.rule = "Mayhem " +
+ " (You may play this card from your graveyard if you discarded it this turn. " +
+ "Timing rules still apply.)";
+ }
+
+ protected MayhemLandAbility(final MayhemLandAbility ability) {
+ super(ability);
+ this.rule = ability.rule;
+ }
+
+ @Override
+ public ActivationStatus canActivate(UUID playerId, Game game) {
+ if (!Zone.GRAVEYARD.match(game.getState().getZone(getSourceId()))
+ || !MayhemWatcher.checkCard(getSourceId(), game)) {
+ return ActivationStatus.getFalse();
+ }
+ return super.canActivate(playerId, game);
+ }
+
+ @Override
+ public boolean activate(Game game, Set allowedIdentifiers, boolean noMana) {
+ if (!super.activate(game, allowedIdentifiers, noMana)) {
+ return false;
+ }
+ this.setCostsTag(MayhemAbility.MAYHEM_ACTIVATION_VALUE_KEY, null);
+ return true;
+ }
+
+ @Override
+ public MayhemLandAbility copy() {
+ return new MayhemLandAbility(this);
+ }
+
+ @Override
+ public String getRule() {
+ return rule;
+ }
+ }
\ No newline at end of file