/* HTML: <div class="vewi-loading-default-icon"></div> */
.vewi-loading-default-icon {
    width: 30px;
    aspect-ratio: 2;
    --_g: no-repeat radial-gradient(circle closest-side,var(--vewi-loading-icon-color) 90%,#0000);
    background: 
      var(--_g) 0%   50%,
      var(--_g) 50%  50%,
      var(--_g) 100% 50%;
    background-size: calc(100%/3) 50%;
    animation: vewi_default_animation 1s infinite linear;
  }
  @keyframes vewi_default_animation {
      20%{background-position:0%   0%, 50%  50%,100%  50%}
      40%{background-position:0% 100%, 50%   0%,100%  50%}
      60%{background-position:0%  50%, 50% 100%,100%   0%}
      80%{background-position:0%  50%, 50%  50%,100% 100%}
  }

.vewi-loading-bar-icon {
  width: 30px;
  aspect-ratio: .75;
  --c: no-repeat linear-gradient(var(--vewi-loading-icon-color) 0 0);
  background: 
    var(--c) 0%   100%,
    var(--c) 50%  100%,
    var(--c) 100% 100%;
  background-size: 20% 65%;
  animation: vewi_bar_animation 1s infinite linear;
}
@keyframes vewi_bar_animation {
  20% {background-position: 0% 50% ,50% 100%,100% 100%}
  40% {background-position: 0% 0%  ,50% 50% ,100% 100%}
  60% {background-position: 0% 100%,50% 0%  ,100% 50% }
  80% {background-position: 0% 100%,50% 100%,100% 0%  }
}

/* HTML: <div class="vewi-loading-spinner-icon"></div> */
.vewi-loading-spinner-icon {
  width: 30px;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 8px solid;
  border-color: var(--vewi-loading-icon-color) #0000;
  animation: vewi_spinner_animation_l1 1s infinite;
}
@keyframes vewi_spinner_animation_l1 {to{transform: rotate(.5turn)}}

/* HTML: <div class="vewi-loading-spinner-2-icon"></div> */
.vewi-loading-spinner-2-icon {
  width: 30px;
  aspect-ratio: 1;
  display: grid;
  border: 4px solid #0000;
  border-radius: 50%;
  border-right-color: var(--vewi-loading-icon-color);
  animation: vewi_spinner_animation_l2 1s infinite linear;
}
.vewi-loading-spinner-2-icon::before,
.vewi-loading-spinner-2-icon::after {    
  content: "";
  grid-area: 1/1;
  margin: 2px;
  border: inherit;
  border-radius: 50%;
  animation: vewi_spinner_animation_l2 2s infinite;
}
.vewi-loading-spinner-2-icon::after {
  margin: 8px;
  animation-duration: 3s;
}
@keyframes vewi_spinner_animation_l2{ 
  100%{transform: rotate(1turn)}
}

/* HTML: <div class="vewi-loading-shape-icon"></div> */
.vewi-loading-shape-icon {
  --c:no-repeat linear-gradient(var(--vewi-loading-icon-color) 0 0);
  background: 
    var(--c),var(--c),var(--c),
    var(--c),var(--c),var(--c),
    var(--c),var(--c),var(--c);
  background-size: 10px 10px;
  animation: 
    vewi_shape_animation 1s infinite,
    vewi_shape_animation_2 1s infinite;
}
@keyframes vewi_shape_animation {
  0%,100% {width:30px;height: 30px}
  35%,65% {width:45px;height: 45px}
}
@keyframes vewi_shape_animation_2 {
  0%,40%  {background-position: 0 0,0 50%, 0 100%,50% 100%,100% 100%,100% 50%,100% 0,50% 0,  50% 50% }
  60%,100%{background-position: 0 50%, 0 100%,50% 100%,100% 100%,100% 50%,100% 0,50% 0,0 0,  50% 50% }
}

/* HTML: <div class="vewi-loading-polygon-icon"></div> */
.vewi-loading-polygon-icon {
  display: inline-flex;
  width: 30px;
  aspect-ratio: 2;
  animation: vewi_polygon_animation 1s linear infinite;
}
.vewi-loading-polygon-icon:before,
.vewi-loading-polygon-icon:after {
  content: "";
  flex: 1;
  background: var(--vewi-loading-icon-color);
  clip-path: polygon(50% 0,100% 50%,50% 100%,0 50%);
  animation: vewi_polygon_animation_2 1s linear infinite;
  transform-origin: right;
}
.vewi-loading-polygon-icon:after {
  scale: -1 1;
  translate: -100% 0;
  animation-direction: reverse;
}
@keyframes vewi_polygon_animation {
  0%{translate: 0 -35.35%}
  to{translate: 0  35.35%}
}
@keyframes vewi_polygon_animation_2 {
  0%{rotate: -45deg}
  to{rotate:  45deg}
}

/* HTML: <div class="vewi-loading-wavy-icon"></div> */
.vewi-loading-wavy-icon {
  display: inline-grid;
  padding: 5px;
  filter: blur(1px) contrast(12);
}
.vewi-loading-wavy-icon:before {
  content: "";
  height: 15px;
  aspect-ratio: 3;
  --c: #0000 64%,var(--vewi-loading-icon-color) 66% 98%,#0000 101%;
  background:
    radial-gradient(35% 146% at 50% 159%,var(--c)) 0 0,
    radial-gradient(35% 146% at 50% -59%,var(--c)) 100% 100%;
  background-size: calc(200%/3) 50%;
  background-repeat: repeat-x;
  animation: vewi_wavy_animation .8s infinite linear;
}
@keyframes vewi_wavy_animation{
  to {background-position: -200% 0,-100% 100%}
}

/* HTML: <div class="vewi-loading-flipping-icon"></div> */
.vewi-loading-flipping-icon {
  width: 30px;
  height: 30px;
  display: flex;
  color: var(--vewi-loading-icon-color);
  background:
    linear-gradient(currentColor 0 0) right  /51% 100%,
    linear-gradient(currentColor 0 0) bottom /100% 51%;
  background-repeat: no-repeat;
  animation: vewi_flipping_animation 2s infinite linear .25s;
}
.vewi-loading-flipping-icon::before{
  content:"";
  width: 50%;
  height: 50%;
  background: currentColor;
  transform-origin: 10% 10%;
  animation:  vewi_flipping_animation_2 .5s infinite linear;
}
@keyframes vewi_flipping_animation {
  0%   ,12.49% {transform: rotate(0deg)}
  12.5%,37.49% {transform: rotate(90deg)}
  37.5%,62.49% {transform: rotate(180deg)}
  62.5%,87.49% {transform: rotate(270deg)}
  87.5%,100%   {transform: rotate(360deg)}
}
@keyframes vewi_flipping_animation_2 {
  0%      {transform: perspective(80px) rotate3d(-1,1,0, 0)}
  80%,100%{transform: perspective(80px) rotate3d(-1,1,0,-360deg)}
}

/* HTML: <div class="vewi-loading-pulsing-icon"></div> */
.vewi-loading-pulsing-icon {
  width: 5px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--vewi-loading-icon-color);
  box-shadow: 0 0 0 0 var(--vewi-loading-icon-color);
  animation: vewi_pulsing_animation 1.5s infinite linear;
  position: relative;
}
.vewi-loading-pulsing-icon:before,
.vewi-loading-pulsing-icon:after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: 0 0 0 0 var(--vewi-loading-icon-color);
  animation: inherit;
  animation-delay: -0.5s;
}
.vewi-loading-pulsing-icon:after {
  animation-delay: -1s;
}
@keyframes vewi_pulsing_animation {
    100% {box-shadow: 0 0 0 20px #0000}
}
/* HTML: <div class="vewi-loading-moving-icon"></div> */
.vewi-loading-moving-icon {
  height: 30px;
  aspect-ratio: 1;
  --c:no-repeat linear-gradient(var(--vewi-loading-icon-color) 0 0);
  background: var(--c), var(--c), var(--c), var(--c);
  background-size: 33.4% 33.4%;
  animation: vewi_moving_animation 2s infinite linear;
}
@keyframes vewi_moving_animation {
  0%    {background-position:0   0  ,50%  0  ,0   50% ,50%  50%}
  12.5% {background-position:50% 0  ,100% 0  ,0   50% ,50%  50%}
  25%   {background-position:50% 0  ,100% 0  ,50% 50% ,100% 50%}
  37.5% {background-position:50% 0  ,100% 50%,50% 50% ,100% 100%}
  50%   {background-position:50% 50%,100% 50%,50% 100%,100% 100%}
  62.5% {background-position:50% 50%,100% 50%,0   100%,50%  100%}
  75%   {background-position:0   50%,50%  50%,0   100%,50%  100%}
  87.5% {background-position:0   0  ,50%  50%,0   50% ,50%  100%}
  100%  {background-position:0   0  ,50%  0  ,0   50% ,50%  50%}
}

/* HTML: <div class="vewi-loading-line-icon"></div> */
.vewi-loading-line-icon {
  width: 30px;
  aspect-ratio: 1;
  --c:no-repeat linear-gradient(var(--vewi-loading-icon-color) 0 0);
  background:
    var(--c) 0 0,
    var(--c) 100% 0,
    var(--c) 100% 100%,
    var(--c) 0 100%;
  animation: 
    vewi_line_animation_1 2s infinite,
    vewi_line_animation_2 2s infinite;
}
@keyframes vewi_line_animation_1 {
  0%   {background-size: 0    4px,4px 0   ,0    4px,4px 0   }
  12.5%{background-size: 100% 4px,4px 0   ,0    4px,4px 0   }
  25%  {background-size: 100% 4px,4px 100%,0    4px,4px 0   }
  37.5%{background-size: 100% 4px,4px 100%,100% 4px,4px 0   }
  45%,
  55%  {background-size: 100% 4px,4px 100%,100% 4px,4px 100%}
  62.5%{background-size: 0    4px,4px 100%,100% 4px,4px 100%}
  75%  {background-size: 0    4px,4px 0   ,100% 4px,4px 100%}
  87.5%{background-size: 0    4px,4px 0   ,0    4px,4px 100%}
  100% {background-size: 0    4px,4px 0   ,0    4px,4px 0   }
}
@keyframes vewi_line_animation_2 {
  0%,49.9%{background-position: 0 0   ,100% 0   ,100% 100%,0 100%}
  50%,100%{background-position: 100% 0,100% 100%,0    100%,0 0   }
}

/* HTML: <div class="vewi-loading-blob-icon"></div> */
.vewi-loading-blob-icon {
  width: 40px;
  aspect-ratio: 1;
  padding: 2px;
  box-sizing: border-box;
  display: grid;
  filter: blur(1px) ;
}
.vewi-loading-blob-icon:before,
.vewi-loading-blob-icon:after{ 
  content: "";
  grid-area: 1/1; 
  width: 20px;
  height: 20px;
  background: var(--vewi-loading-icon-color);
  animation: l7 2s infinite;
}
.vewi-loading-blob-icon:after{ 
  animation-delay: -1s;
}
@keyframes l7{
  0%   {transform: translate(   0,0)}
  25%  {transform: translate(100%,0)}
  50%  {transform: translate(100%,100%)}
  75%  {transform: translate(   0,100%)}
  100% {transform: translate(   0,0)}
}