.loader {
    position: relative;
    width: 2.5em;
    height: 2.5em;
    transform: rotate(165deg);
  }
  .loader:before, .loader:after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    width: 0.3em;
    height: 0.3em;
    border-radius: 0.25em;
    transform: translate(-50%, -50%);
  }
  .loader:before {
    animation: before 2s infinite;
  }
  .loader:after {
    animation: after 2s infinite;
  }
  
  /* 
  @keyframes before {
    0% {
      width: 0.5em;
      box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);
    }
    35% {
      width: 2.5em;
      box-shadow: 0 -0.5em rgba(225, 20, 98, 0.75), 0 0.5em rgba(111, 202, 220, 0.75);
    }
    70% {
      width: 0.5em;
      box-shadow: -1em -0.5em rgba(225, 20, 98, 0.75), 1em 0.5em rgba(111, 202, 220, 0.75);
    }
    100% {
      box-shadow: 1em -0.5em rgba(225, 20, 98, 0.75), -1em 0.5em rgba(111, 202, 220, 0.75);
    }
  }
  @keyframes after {
    0% {
      height: 0.5em;
      box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);
    }
    35% {
      height: 2.5em;
      box-shadow: 0.5em 0 rgba(61, 184, 143, 0.75), -0.5em 0 rgba(233, 169, 32, 0.75);
    }
    70% {
      height: 0.5em;
      box-shadow: 0.5em -1em rgba(61, 184, 143, 0.75), -0.5em 1em rgba(233, 169, 32, 0.75);
    }
    100% {
      box-shadow: 0.5em 1em rgba(61, 184, 143, 0.75), -0.5em -1em rgba(233, 169, 32, 0.75);
    }
  }
  */

  /*
  @keyframes before {
    0% {
      width: 0.5em;
      box-shadow: 1em -0.5em rgba(8,255,200,0.747), -1em 0.5em rgba(29, 64, 90, 0.647);
    }
    35% {
      width: 2.5em;
      box-shadow: 0 -0.5em rgba(8,255,200,0.747), 0 0.5em rgba(29, 64, 90, 0.647);
    }
    70% {
      width: 0.5em;
      box-shadow: -1em -0.5em rgba(8,255,200,0.747), 1em 0.5em rgba(29, 64, 90, 0.647);
    }
    100% {
      box-shadow: 1em -0.5em rgba(8,255,200,0.747), -1em 0.5em rgba(29, 64, 90, 0.647);
    }
  }
  @keyframes after {
    0% {
      height: 0.5em;
      box-shadow: 0.5em 1em rgba(255, 246, 164, 0.767), -0.5em -1em rgba(218, 218, 218, 0.747);
    }
    35% {
      height: 2.5em;
      box-shadow: 0.5em 0 rgba(255, 246, 164, 0.767), -0.5em 0 rgba(218,218,218,0.747);
    }
    70% {
      height: 0.5em;
      box-shadow: 0.5em -1em rgba(255, 246, 164, 0.767), -0.5em 1em rgba(218,218,218,0.747);
    }
    100% {
      box-shadow: 0.5em 1em rgba(255, 246, 164, 0.767), -0.5em -1em rgba(218,218,218,0.747);
    }
  }
  */

  @keyframes before {
    0% {
      width: 0.5em;
      box-shadow: 1em -0.5em #9ccc72, -1em 0.5em #8cdaf9;
    }
    35% {
      width: 2.5em;
      box-shadow: 0 -0.5em #9ccc72, 0 0.5em #8cdaf9;
    }
    70% {
      width: 0.5em;
      box-shadow: -1em -0.5em #9ccc72, 1em 0.5em #8cdaf9;
    }
    100% {
      box-shadow: 1em -0.5em #9ccc72, -1em 0.5em #8cdaf9;
    }
  }
  @keyframes after {
    0% {
      height: 0.5em;
      box-shadow: 0.5em 1em rgba(254, 255, 168, 0.729), -0.5em -1em rgba(218, 218, 218, 0.647);
    }
    35% {
      height: 2.5em;
      box-shadow: 0.5em 0 rgba(254, 255, 168, 0.729), -0.5em 0 rgba(218,218,218,0.647);
    }
    70% {
      height: 0.5em;
      box-shadow: 0.5em -1em rgba(254, 255, 168, 0.729), -0.5em 1em rgba(218,218,218,0.647);
    }
    100% {
      box-shadow: 0.5em 1em rgba(254, 255, 168, 0.729), -0.5em -1em rgba(218,218,218,0.647);
    }
  }

  /**
   * Attempt to center the whole thing!
   */
  html,
  body {
    height: 100%;
  }
  
  .loader_section{
    width: 100%;
    height: 100%;
    margin: auto;
    background: white;
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: 99999;
	display: flex;
  	align-items: center;
    justify-content: center;  
  }

  .loader {
    position: absolute;
    top: calc(45% - 1.25em);
    left: calc(50% - 1.25em);
  }