
#yin-yang {
    width: 96px;
    box-sizing: content-box;
    height: 48px;
    background: #eee;
    border-color: red;
    border-style: solid;
    border-width: 2px 2px 50px 2px;
    border-radius: 100%;
    position: relative;
    transition: all 0.5s ease-in;
    
  }
  #yin-yang:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    background: #eee;
    border: 18px solid rgb(255, 0, 0);
    border-radius: 100%;
    width: 12px;
    height: 12px;
    box-sizing: content-box;
    transition: all 0.5s ease-in;
  }
  #yin-yang:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    background: red;
    border: 18px solid #eee;
    border-radius: 100%;
    width: 12px;
    height: 12px;
    box-sizing: content-box;
    transition: all 0.5s ease-in;
  }

  #yin-yang.change-me {
    background: purple;
    border-color: blueviolet;
    transform: translateX(1000px) 
    rotate(100deg) 
    rotateY(10deg)

  }
  #yin-yang.change-me:after {
    border: 18px solid purple;
    background: blueviolet;
  }
  #yin-yang.change-me:before {
    background: purple;
    border: 18px solid blueviolet;

  }