.shellcard {
  background: var(--accent);
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 120px;
  margin-top: 40px;
  position: relative;
  min-width: 0;
  max-width: none;
}
.shellcard-image {
  flex: 1 1 500px;
  position: relative;
}
@media (max-width: 600px) {
  .shellcard-image {
    order: -1;
  }
}
.shellcard-image img {
  object-fit: cover;
  width: 100%;
  aspect-ratio: 6/4;
  display: block;
  height: 100%;
}
.shellcard-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--accent);
  mix-blend-mode: multiply;
  opacity: 0;
  transition: opacity 240ms ease-out;
  pointer-events: none;
}
.shellcard:has(.button):hover .shellcard-image::after {
  opacity: 0.8;
}
.shellcard-text {
  color: var(--text);
  padding: 36px;
  flex: 1 1 250px;
  display: flex;
  flex-direction: column;
  align-items: start;
}
.shellcard-text a:not(.button) {
  color: var(--text);
  position: relative;
  z-index: 2;
  text-decoration-color: var(--text);
}
.shellcard-text * {
  max-width: 330px;
}
.shellcard-text .button {
  margin-top: auto;
  padding: 12px 36px;
  font-size: 20px;
}
.shellcard-text .button:hover, .shellcard-text .button:focus {
  background: var(--ocean-dark);
}
.shellcard-text > *:last-child {
  margin-bottom: 0;
}
.shellcard--reverse .shellcard-image {
  order: -1;
}
.shellcard--mineral {
  color: var(--navy);
}
.shellcard--mineral .shellcard-text a {
  color: var(--navy);
}
.shellcard--mineral a.button:hover {
  border-color: var(--ocean-dark);
  color: white;
}
.shellcard--ocean-light {
  color: var(--navy);
}
.shellcard--ocean-light .shellcard-text a {
  color: var(--navy);
}
.shellcard--ocean-light a.button {
  background-color: var(--navy);
  border-color: var(--navy);
  color: white;
  text-decoration: none;
}
.shellcard--ocean-light a.button:hover {
  background-color: var(--ocean-dark);
  border-color: var(--ocean-dark);
}
.shellcard--ocean-dark a.button {
  text-decoration: none;
}
.shellcard--ocean-dark a.button:hover {
  background-color: var(--mineral);
  border-color: var(--mineral);
  color: var(--navy);
}
.shellcard--sand {
  color: var(--navy);
}
.shellcard--sand .shellcard-text a {
  color: var(--navy);
}
.shellcard--sand a.button {
  background-color: var(--orange);
  border-color: var(--orange);
  color: var(--navy);
  text-decoration: none;
}
.shellcard--sand a.button:hover {
  color: white;
  background-color: var(--ocean-dark);
  border-color: var(--ocean-dark);
}
.shellcard--lime {
  color: var(--navy);
}
.shellcard--lime .shellcard-text a {
  color: var(--navy);
}
.shellcard--lime a.button {
  border-color: var(--ocean-dark);
  background-color: var(--ocean-dark);
  color: white;
  text-decoration: none;
}
.shellcard--lime a.button:hover {
  background-color: var(--mineral);
  border-color: var(--mineral);
  color: var(--navy);
}
.shellcard--orange {
  color: var(--navy);
}
.shellcard--orange .shellcard-text a {
  color: var(--navy);
}
.shellcard--orange a.button {
  border-color: var(--navy);
  background-color: var(--navy);
  text-decoration: none;
  color: white;
}
.shellcard--orange a.button:hover {
  background-color: var(--sand);
  border-color: var(--sand);
  color: var(--navy);
}

.main-content .shellcard-text a:not(.button):not(.wp-block-button__link) {
  text-decoration-color: var(--text) !important;
}
