<div class="nintendo">
      <div class="container">
        <div class="heart-wrapper">
          <svg
            xmlns="http://www.w3.org/2000/svg"
            viewBox="0 0 24 24"
            class="heart"
          >
            <path
              d="M12 4.435c-1.989-5.399-12-4.597-12 3.568 0 4.068 3.06 9.481 12 14.997 8.94-5.516 12-10.929 12-14.997 0-8.118-10-8.999-12-3.568z"
            />
          </svg>
        </div>
      </div>
      <div class="nintendo-right">
        <div class="minor-buttons"></div>
        <div class="major-button"></div>
        <div class="extra-button"></div>
        <div class="plus-button">
          <div class="minus-button"></div>
          <div class="minus-button"></div>
        </div>
      </div>
      <div class="nintendo-left">
        <div class="minor-buttons"></div>
        <div class="major-button"></div>
        <div class="extra-button"></div>
        <div class="minus-button"></div>
      </div>
      <div class="intersection-right">
        <div class="intersection-left"></div>
      </div>
    </div>
:root {
  --width: 610px;
  --height: 270px;
  --border-radius: 40px;
  --gap: 45px;
  --red: #fe4b3c;
  --blue: #03b9e2;
  --dark: #191c30;

  --heart-size: 120px;
  --major-size: 45px;
  --major-button-position-horizontal: 25px;
  --minor-size: 21px;
  --minor-button-position: 35px;
  --left-extra-button-size: 17px;
  --right-extra-button-size: 21px;
  --extra-button-position-horizontal: 60px;
  --extra-button-position-vertical: 175px;
  --minus-length: 17px;
  --minus-thick: 6px;
  --minus-radius: 2px;
}

.container {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.heart-wrapper {
  position: relative;
  width: var(--heart-size);
  height: var(--heart-size);
}
.heart {
  fill: var(--red);
  width: var(--heart-size);
  height: var(--heart-size);
}

.nintendo-left,
.nintendo-right {
  width: 100%;
  height: 100%;
  border-radius: var(--border-radius);
  position: absolute;
}
.nintendo-left {
  background: var(--blue);
  left: calc(-1 * var(--gap));
  top: -5px;
}
.nintendo-right {
  background: var(--red);
  right: calc(-1 * var(--gap));
  bottom: -5px;
}
.nintendo {
  position: relative;
  margin: 40px auto;
  width: var(--width);
  height: var(--height);
}
.intersection-left {
  position: absolute;
  top: -10px;
  width: 100%;
  left: calc(-1 * var(--gap));
  height: calc(100%);
  background: var(--dark);
  border-top-right-radius: var(--border-radius);
  border-bottom-right-radius: var(--border-radius);
}
.intersection-right {
  overflow: hidden;
  top: 5px;
  width: calc(100% - var(--gap));
  height: 100%;
  position: relative;
  right: calc(-1 * var(--gap));
  border-top-left-radius: var(--border-radius);
  border-bottom-left-radius: var(--border-radius);
}

.major-button {
  border-radius: 50%;
/*   box-shadow: rgba(0, 0, 0, 0.4) 2px 2px 0 1px; */
  width: var(--major-size);
  height: var(--major-size);
  background: var(--dark);
  position: absolute;
}
.nintendo-left > .major-button {
  top: 45px;
  left: var(--major-button-position-horizontal);
}
.nintendo-right > .major-button {
  right: var(--major-button-position-horizontal);
  top: 115px;
}

.minor-buttons {
  width: var(--minor-size);
  height: var(--minor-size);
  background: var(--dark);
  position: absolute;
  border-radius: 50%;
  box-shadow: var(--dark) var(--minor-size) var(--minor-size) 0 0,
    var(--dark) calc(var(--minor-size) * -1) var(--minor-size) 0 0,
    var(--dark) 0 calc(var(--minor-size) * 2) 0 0;
}

.nintendo-right > .minor-buttons {
  right: var(--minor-button-position);
  top: 30px;
}

.nintendo-left > .minor-buttons {
  top: 110px;
  left: var(--minor-button-position);
}

.extra-button {
  background: var(--dark);
  position: absolute;
}
.nintendo-left > .extra-button {
  width: var(--left-extra-button-size);
  height: var(--left-extra-button-size);
  border-radius: 4px;
  left: var(--extra-button-position-horizontal);
  top: calc(var(--extra-button-position-vertical) + 10px);
}

.nintendo-right > .extra-button {
  width: var(--right-extra-button-size);
  height: var(--right-extra-button-size);
  border-radius: 50%;
  right: var(--extra-button-position-horizontal);
  top: calc(var(--extra-button-position-vertical));
}

.minus-button {
  width: var(--minus-length);
  height: var(--minus-thick);
  border-radius: var(--minus-radius);
  position: absolute;
  background: var(--dark);
}
.nintendo-left > .minus-button {
  left: 66px;
  top: 25px;
}

.nintendo-right > .plus-button {
  right: 85px;
  top: 17px;
  position: absolute;
}
.nintendo-right > .plus-button > .minus-button:nth-child(2) {
  transform: rotate(90deg);
}
Run Pen

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.